/* ============================================================
   NÚRIA BOLADERES — COMPONENTS
   Reusable UI built on tokens.css + base.css.
   ============================================================ */

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);
  font-family:var(--font-text);font-size:var(--fs-xs);font-weight:var(--fw-medium);
  letter-spacing:var(--ls-label);text-transform:uppercase;
  padding:var(--space-4) var(--space-6);border-radius:var(--r-pill);
  border:1px solid transparent;cursor:pointer;text-align:center;
  transition:background var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out),
             border-color var(--dur-base) var(--ease-out),transform var(--dur-fast) var(--ease-out),
             box-shadow var(--dur-base) var(--ease-out);
}
.btn:active{transform:translateY(1px);}
.btn:focus-visible{outline:none;box-shadow:var(--focus-ring);}
.btn .icon{width:1em;height:1em;}

.btn-primary{background:var(--accent);color:var(--on-accent);}
.btn-primary:hover{background:var(--ink);}
.btn-primary:active{background:var(--accent-strong);color:var(--c-linen);}
.btn-primary[disabled],.btn-primary.is-disabled{background:var(--ink-ghost);color:var(--ink-faint);cursor:not-allowed;pointer-events:none;}

.btn-secondary{background:transparent;border-color:var(--line);color:var(--ink);}
.btn-secondary:hover{border-color:var(--accent);color:var(--ink);background:var(--surface);}
.btn-secondary:active{border-color:var(--accent-strong);}
.btn-secondary[disabled]{border-color:var(--line-soft);color:var(--ink-ghost);cursor:not-allowed;pointer-events:none;}

.btn-tertiary{background:var(--surface);color:var(--ink-soft);}
.btn-tertiary:hover{background:var(--surface-2);color:var(--ink);}

.btn-text{background:none;border:0;border-radius:0;padding:var(--space-2) 0;color:var(--accent);letter-spacing:var(--ls-eyebrow);}
.btn-text:hover{color:var(--ink);}
.btn-text .arr{transition:transform var(--dur-base) var(--ease-out);}
.btn-text:hover .arr{transform:translateX(5px);}

.btn-icon{padding:0;width:46px;height:46px;border-radius:var(--r-circle);border-color:var(--line);background:transparent;}
.btn-icon:hover{border-color:var(--accent);background:var(--surface);}

/* FAB */
.fab{position:fixed;right:var(--space-6);bottom:var(--space-6);z-index:var(--z-sticky);
  width:56px;height:56px;border-radius:var(--r-circle);background:var(--accent);color:var(--on-accent);
  border:0;box-shadow:var(--shadow-2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;}
.fab:hover{background:var(--ink);}

/* sizes */
.btn-sm{padding:var(--space-3) var(--space-5);font-size:11px;}
.btn-lg{padding:var(--space-5) var(--space-7);font-size:var(--fs-xs);}
.btn-block{width:100%;}

/* ============ FORMS ============ */
.field{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-5);}
.field > label,.field-label{font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);font-weight:var(--fw-medium);}
.input,.textarea,.select{
  width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:var(--space-4);color:var(--ink);font-size:var(--fs-sm);font-family:var(--font-text);
  transition:border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out);
}
.input::placeholder,.textarea::placeholder{color:var(--ink-ghost);}
.input:hover,.textarea:hover,.select:hover{border-color:var(--ink-faint);}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--accent);background:var(--surface-2);box-shadow:0 0 0 3px rgba(122,132,110,.14);}
.textarea{min-height:120px;resize:vertical;line-height:1.6;}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239A8F7F' stroke-width='1.4' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center;padding-right:var(--space-7);}

/* underline variant (used in hero/footer for airy feel) */
.input-line{background:none;border:0;border-bottom:1px solid var(--line);border-radius:0;padding:var(--space-4) 0;}
.input-line:focus{box-shadow:none;border-bottom-color:var(--accent);background:none;}

/* states */
.field.is-error .input,.input.is-error{border-color:var(--error);}
.field.is-success .input,.input.is-success{border-color:var(--success);}
.input[disabled],.textarea[disabled],.select[disabled]{opacity:.5;cursor:not-allowed;}
.field-hint{font-size:var(--fs-xs);color:var(--ink-faint);}
.field-hint.error{color:var(--error);}
.field-hint.success{color:var(--success);}

/* checkbox & radio */
.check,.radio{display:inline-flex;align-items:flex-start;gap:var(--space-3);cursor:pointer;font-size:var(--fs-sm);color:var(--ink-soft);}
.check input,.radio input{position:absolute;opacity:0;width:0;height:0;}
.check .box,.radio .box{flex:0 0 auto;width:20px;height:20px;border:1px solid var(--line);background:var(--surface);transition:all var(--dur-fast) var(--ease-out);display:inline-flex;align-items:center;justify-content:center;margin-top:1px;}
.check .box{border-radius:var(--r-xs);}
.radio .box{border-radius:var(--r-circle);}
.check input:checked + .box{background:var(--accent);border-color:var(--accent);}
.check input:checked + .box::after{content:"";width:5px;height:9px;border:solid var(--on-accent);border-width:0 1.5px 1.5px 0;transform:rotate(45deg) translateY(-1px);}
.radio input:checked + .box{border-color:var(--accent);}
.radio input:checked + .box::after{content:"";width:9px;height:9px;border-radius:var(--r-circle);background:var(--accent);}
.check input:focus-visible + .box,.radio input:focus-visible + .box{box-shadow:var(--focus-ring);}

/* switch */
.switch{display:inline-flex;align-items:center;gap:var(--space-3);cursor:pointer;}
.switch input{position:absolute;opacity:0;}
.switch .track{width:46px;height:26px;border-radius:var(--r-pill);background:var(--surface-2);border:1px solid var(--line);position:relative;transition:all var(--dur-base) var(--ease-out);}
.switch .track::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:var(--r-circle);background:var(--ink-soft);transition:all var(--dur-base) var(--ease-out);}
.switch input:checked + .track{background:var(--accent);border-color:var(--accent);}
.switch input:checked + .track::after{transform:translateX(20px);background:var(--on-accent);}

/* upload */
.upload{border:1px dashed var(--line);border-radius:var(--r-md);padding:var(--space-7);text-align:center;color:var(--ink-faint);background:var(--surface);transition:all var(--dur-fast) var(--ease-out);cursor:pointer;}
.upload:hover{border-color:var(--accent);color:var(--ink-soft);background:var(--surface-2);}

/* ============ TAGS, BADGES, PILLS ============ */
.tag{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--fs-xs);letter-spacing:.04em;color:var(--ink-soft);border:1px solid var(--line);border-radius:var(--r-pill);padding:var(--space-2) var(--space-4);transition:all var(--dur-fast) var(--ease-out);}
.tag:hover{border-color:var(--accent);color:var(--ink);}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:var(--fw-medium);padding:4px 10px;border-radius:var(--r-pill);}
.badge-neutral{background:var(--surface-2);color:var(--ink-soft);}
.badge-accent{background:var(--accent);color:var(--on-accent);}
.badge-dot{width:6px;height:6px;border-radius:var(--r-circle);background:currentColor;display:inline-block;}

/* ============ CARDS ============ */
.card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r-md);padding:var(--space-6);transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out),background var(--dur-base) var(--ease-out);}
.card.is-interactive{cursor:pointer;}
.card.is-interactive:hover{border-color:var(--line);transform:translateY(-3px);background:var(--surface-2);}
.card-media{border-radius:var(--r-sm);overflow:hidden;margin:calc(var(--space-6)*-1) calc(var(--space-6)*-1) var(--space-5);aspect-ratio:16/10;}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease-out);}
.card.is-interactive:hover .card-media img{transform:scale(1.05);}
.card-title{font-family:var(--font-display);font-size:var(--fs-h4);margin-bottom:var(--space-2);}
.card-meta{font-size:var(--fs-xs);color:var(--ink-faint);letter-spacing:.04em;}

/* profile card */
.card-profile{text-align:center;}
.card-profile .avatar{margin:0 auto var(--space-4);}

/* stat card */
.card-stat .stat-num{font-family:var(--font-display);font-size:var(--fs-h1);color:var(--ink);line-height:1;}
.card-stat .stat-label{font-size:var(--fs-xs);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-top:var(--space-3);}

/* feature card with rule */
.card-feature{border:0;border-top:1px solid var(--line);border-radius:0;background:none;padding:var(--space-6) 0 0;}

/* ============ AVATARS ============ */
.avatar{width:48px;height:48px;border-radius:var(--r-circle);overflow:hidden;background:var(--surface-2);border:1px solid var(--line-soft);flex:0 0 auto;}
.avatar img{width:100%;height:100%;object-fit:cover;}
.avatar-sm{width:32px;height:32px;}
.avatar-lg{width:88px;height:88px;}
.avatar-group{display:flex;}
.avatar-group .avatar{margin-left:-12px;border:2px solid var(--bg);}
.avatar-group .avatar:first-child{margin-left:0;}

/* ============ NAVIGATION ============ */
.site-header{position:sticky;top:0;z-index:var(--z-nav);display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--gutter);backdrop-filter:blur(10px);background:linear-gradient(180deg,rgba(21,23,15,.7),transparent);transition:background var(--dur-base) var(--ease-out);}
.site-header.is-scrolled{background:rgba(21,23,15,.92);border-bottom:1px solid var(--line-soft);}
.brand-lockup{font-family:var(--font-display);font-weight:var(--fw-light);font-size:1.4rem;letter-spacing:.01em;color:var(--ink);}
.nav-primary{display:flex;align-items:center;gap:var(--space-6);}
.nav-primary a{font-size:var(--fs-xs);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);transition:color var(--dur-fast) var(--ease-out);position:relative;}
.nav-primary a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--accent);transition:width var(--dur-base) var(--ease-out);}
.nav-primary a:hover,.nav-primary a.is-active{color:var(--ink);}
.nav-primary a:hover::after,.nav-primary a.is-active::after{width:100%;}
@media(max-width:768px){.nav-primary{display:none;}}
.nav-toggle{display:none;}
@media(max-width:768px){.nav-toggle{display:inline-flex;}}

/* dropdown */
.dropdown{position:relative;}
.dropdown-menu{position:absolute;top:calc(100% + 12px);left:0;min-width:200px;background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--space-2);box-shadow:var(--shadow-3);opacity:0;visibility:hidden;transform:translateY(-6px);transition:all var(--dur-base) var(--ease-out);}
.dropdown:hover .dropdown-menu,.dropdown.is-open .dropdown-menu{opacity:1;visibility:visible;transform:none;}
.dropdown-menu a{display:block;padding:var(--space-3) var(--space-4);font-size:var(--fs-sm);color:var(--ink-soft);border-radius:var(--r-sm);}
.dropdown-menu a:hover{background:var(--surface);color:var(--ink);}

/* breadcrumbs */
.breadcrumb{display:flex;align-items:center;gap:var(--space-3);font-size:var(--fs-xs);color:var(--ink-faint);}
.breadcrumb a:hover{color:var(--ink);}
.breadcrumb .sep{opacity:.5;}

/* pagination */
.pagination{display:flex;align-items:center;gap:var(--space-2);}
.pagination a,.pagination span{min-width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);font-size:var(--fs-sm);color:var(--ink-soft);border:1px solid transparent;transition:all var(--dur-fast) var(--ease-out);}
.pagination a:hover{border-color:var(--line);color:var(--ink);}
.pagination .is-current{background:var(--surface-2);color:var(--ink);border-color:var(--line);}

/* footer */
.site-footer{border-top:1px solid var(--line-soft);padding:var(--space-9) var(--gutter) var(--space-6);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--space-7);}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr;}}
.footer-col h5{font-size:var(--fs-xs);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 var(--space-4);font-weight:var(--fw-medium);}
.footer-col a{display:block;color:var(--ink-soft);font-size:var(--fs-sm);padding:var(--space-1) 0;}
.footer-col a:hover{color:var(--ink);}
.footer-base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-8);padding-top:var(--space-5);border-top:1px solid var(--line-soft);font-size:var(--fs-xs);color:var(--ink-faint);letter-spacing:.06em;}

/* ============ CONTENT COMPONENTS ============ */
/* accordion */
.accordion{border-top:1px solid var(--line-soft);}
.accordion-item{border-bottom:1px solid var(--line-soft);}
.accordion-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);background:none;border:0;cursor:pointer;padding:var(--space-5) 0;text-align:left;color:var(--ink);font-family:var(--font-display);font-size:var(--fs-h4);}
.accordion-trigger .plus{flex:0 0 auto;width:20px;height:20px;position:relative;}
.accordion-trigger .plus::before,.accordion-trigger .plus::after{content:"";position:absolute;background:var(--accent);transition:transform var(--dur-base) var(--ease-out);}
.accordion-trigger .plus::before{top:50%;left:0;width:100%;height:1px;transform:translateY(-50%);}
.accordion-trigger .plus::after{left:50%;top:0;height:100%;width:1px;transform:translateX(-50%);}
.accordion-item.is-open .plus::after{transform:translateX(-50%) scaleY(0);}
.accordion-panel{max-height:0;overflow:hidden;transition:max-height var(--dur-slow) var(--ease-out);}
.accordion-panel-inner{padding-bottom:var(--space-5);color:var(--ink-soft);font-size:var(--fs-sm);max-width:58ch;}

/* tooltip */
.tooltip{position:relative;display:inline-flex;}
.tooltip .tip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--bg-deep);border:1px solid var(--line);color:var(--ink);font-size:var(--fs-xs);padding:var(--space-2) var(--space-3);border-radius:var(--r-sm);white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--dur-fast) var(--ease-out);box-shadow:var(--shadow-2);pointer-events:none;}
.tooltip:hover .tip{opacity:1;visibility:visible;transform:translateX(-50%);}

/* table */
.table{width:100%;border-collapse:collapse;font-size:var(--fs-sm);}
.table th{text-align:left;font-weight:var(--fw-medium);font-size:var(--fs-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--line);}
.table td{padding:var(--space-4);border-bottom:1px solid var(--line-soft);color:var(--ink-soft);}
.table tr:hover td{background:var(--surface);color:var(--ink);}

/* quiet quote (signature pattern) */
.quote-quiet{text-align:center;max-width:26ch;margin-inline:auto;}
.quote-quiet blockquote{font-size:var(--fs-h2);}
.quote-quiet .cite{display:block;margin-top:var(--space-6);font-family:var(--font-text);font-style:normal;font-size:var(--fs-xs);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);}

/* ============ FEEDBACK ============ */
.alert{display:flex;gap:var(--space-3);align-items:flex-start;padding:var(--space-4) var(--space-5);border-radius:var(--r-md);border:1px solid var(--line);font-size:var(--fs-sm);}
.alert .a-dot{flex:0 0 auto;width:8px;height:8px;border-radius:var(--r-circle);margin-top:7px;}
.alert-success{background:var(--success-bg);border-color:rgba(94,122,82,.4);}
.alert-success .a-dot{background:var(--success);}
.alert-warning{background:var(--warning-bg);border-color:rgba(181,154,106,.4);}
.alert-warning .a-dot{background:var(--warning);}
.alert-error{background:var(--error-bg);border-color:rgba(160,96,84,.45);}
.alert-error .a-dot{background:var(--error);}
.alert-info{background:var(--info-bg);border-color:rgba(110,139,142,.4);}
.alert-info .a-dot{background:var(--info);}

/* toast */
.toast{display:flex;align-items:center;gap:var(--space-3);background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-3);font-size:var(--fs-sm);}

/* progress */
.progress{height:3px;background:var(--surface-2);border-radius:var(--r-pill);overflow:hidden;}
.progress-bar{height:100%;background:var(--accent);border-radius:var(--r-pill);transition:width var(--dur-slow) var(--ease-out);}
.progress-ring{width:36px;height:36px;border-radius:var(--r-circle);border:2px solid var(--surface-2);border-top-color:var(--accent);animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* skeleton / loading */
.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--surface-2) 37%,var(--surface) 63%);background-size:400% 100%;animation:shimmer 1.6s ease infinite;border-radius:var(--r-sm);}
@keyframes shimmer{0%{background-position:100% 0;}100%{background-position:-100% 0;}}

/* empty state */
.empty-state{text-align:center;padding:var(--space-9) var(--space-5);color:var(--ink-faint);}
.empty-state .es-mark{width:56px;height:56px;border-radius:var(--r-circle);border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);}

/* ============ OVERLAYS: MODAL / DRAWER / POPOVER ============ */
.scrim{position:fixed;inset:0;background:rgba(16,19,11,.7);backdrop-filter:blur(4px);z-index:var(--z-overlay);}
.modal{position:fixed;z-index:var(--z-modal);top:50%;left:50%;transform:translate(-50%,-50%);width:min(520px,92vw);background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--space-7);box-shadow:var(--shadow-3);}
.drawer{position:fixed;z-index:var(--z-modal);top:0;right:0;height:100%;width:min(420px,92vw);background:var(--bg-deep);border-left:1px solid var(--line);padding:var(--space-7);box-shadow:var(--shadow-3);}
.popover{position:absolute;z-index:var(--z-overlay);background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--space-4);box-shadow:var(--shadow-3);min-width:220px;}
.sheet{position:fixed;z-index:var(--z-modal);left:0;right:0;bottom:0;background:var(--bg-deep);border-top:1px solid var(--line);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:var(--space-7);box-shadow:var(--shadow-3);}

/* ============ MEDIA ============ */
.figure{overflow:hidden;border-radius:var(--r-sm);position:relative;background:var(--bg-deep);}
.figure img{width:100%;height:100%;object-fit:cover;filter:saturate(.94) brightness(.96);transition:transform var(--dur-slow) var(--ease-out),filter var(--dur-slow) var(--ease-out);}
.figure:hover img{transform:scale(1.04);filter:saturate(1) brightness(1);}
.figure.dim img{filter:saturate(.9) brightness(.6);}
.figure.dim:hover img{filter:saturate(1) brightness(.8);}
.ratio-portrait{aspect-ratio:3/4;}
.ratio-landscape{aspect-ratio:16/10;}
.ratio-square{aspect-ratio:1;}
.ratio-door{aspect-ratio:3/4.2;}
