/* ================================================================
   CRÈME — Complete CSS
   
   Light warm editorial theme
   Palette: Cream #FAF7F2 · Warm gray #2C2926 · Terracotta #C67D5B · Sage #8B9A7E
   Fonts: Fraunces (display, optical-sizing) + Plus Jakarta Sans (body)
   ================================================================ */

/* @import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,300;1,9..144,400;1,9..144,500&family=Plus+Jakarta+Sans:ital,wght@0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap'); */

/* ─── TOKENS ─── */
:root{
  /* surfaces */
  --cream:#FAF7F2;--cream-dark:#F0EBE3;--cream-deep:#E5DED4;
  --white:#FFFFFF;--paper:#F5F1EB;

  /* text */
  --ink:#2C2926;--ink-70:rgba(44,41,38,.7);--ink-40:rgba(44,41,38,.4);
  --ink-20:rgba(44,41,38,.2);--ink-10:rgba(44,41,38,.1);--ink-05:rgba(44,41,38,.05);

  /* accents */
  --terra:#C67D5B;--terra-light:#D4956F;--terra-dark:#A8654A;--terra-wash:rgba(198,125,91,.08);--terra-glow:rgba(198,125,91,.18);
  --sage:#8B9A7E;--sage-light:#A3B096;--sage-wash:rgba(139,154,126,.1);
  --blush:#E8C4B0;

  /* functional */
  --wa:#25d366;--tg:#0088cc;
  --bd:rgba(44,41,38,.08);--bd-2:rgba(44,41,38,.12);--bd-3:rgba(44,41,38,.18);

  /* shadows — warm tinted */
  --sh-xs:0 1px 2px rgba(44,41,38,.04);
  --sh-sm:0 2px 8px rgba(44,41,38,.06);
  --sh-md:0 4px 20px rgba(44,41,38,.08);
  --sh-lg:0 8px 40px rgba(44,41,38,.1);
  --sh-xl:0 20px 60px rgba(44,41,38,.12);
  --sh-card:0 2px 12px rgba(44,41,38,.06),0 0 0 1px rgba(44,41,38,.04);
  --sh-card-hover:0 12px 40px rgba(44,41,38,.12),0 0 0 1px var(--terra-glow);

  /* spacing */
  --sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;
  --sp-8:32px;--sp-10:40px;--sp-12:48px;--sp-14:56px;--sp-16:64px;--sp-20:80px;--sp-24:96px;

  /* radius */
  --r-xs:6px;--r-sm:10px;--r-md:14px;--r-lg:20px;--r-xl:28px;--r-2xl:36px;--r-full:9999px;

  /* type */
  --ff-d:'Fraunces',Georgia,serif;
  --ff-b:'Plus Jakarta Sans',-apple-system,sans-serif;

  /* layout */
  --hdr-h:72px;--max-w:1380px;

  /* motion */
  --ease:cubic-bezier(.4,0,.2,1);--ease-out:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);--ease-bounce:cubic-bezier(.68,-.55,.265,1.55);
  --dur:.2s;--dur-slow:.35s;--dur-long:.5s;
}

/* ─── RESET ─── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-b);font-size:15px;font-weight:400;line-height:1.65;
  color:var(--ink);background:var(--cream);min-height:100dvh;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;-webkit-tap-highlight-color:transparent}
ul,ol{list-style:none}
input,select,textarea{font:inherit}
::selection{background:var(--terra);color:var(--white)}

::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--cream-deep);border-radius:var(--r-full)}
::-webkit-scrollbar-thumb:hover{background:var(--terra)}
html{scrollbar-width:thin;scrollbar-color:var(--cream-deep) var(--cream)}
:focus-visible{outline:2px solid var(--terra);outline-offset:3px;border-radius:var(--r-xs)}

.container{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--sp-5)}
@media(min-width:768px){.container{padding-inline:var(--sp-8)}}
@media(min-width:1280px){.container{padding-inline:var(--sp-12)}}


/* ================================================================
   HEADER — pill-shaped floating bar
   ================================================================ */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:var(--sp-3) var(--sp-5);
}
.header__bar{
  max-width:var(--max-w);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  height:54px;padding:0 var(--sp-4) 0 var(--sp-5);
  background:rgba(255,255,255,.88);
  -webkit-backdrop-filter:blur(20px) saturate(1.6);backdrop-filter:blur(20px) saturate(1.6);
  border:1px solid var(--bd);border-radius:var(--r-full);
  box-shadow:var(--sh-sm);
  transition:all var(--dur) var(--ease);
}
.header.scrolled .header__bar{box-shadow:var(--sh-md);background:rgba(255,255,255,.95)}

/* Logo — handwritten feel */
.logo{
  display:flex;align-items:center;gap:var(--sp-3);
  position:relative;z-index:1050;flex-shrink:0;
}
.logo__mark{
  width:34px;height:34px;display:grid;place-items:center;
  background:var(--terra);border-radius:var(--r-sm);color:var(--white);
  font-family:var(--ff-d);font-size:.85rem;font-weight:500;font-style:italic;
  transition:transform var(--dur) var(--ease-spring);
}
.logo:hover .logo__mark{transform:rotate(-6deg) scale(1.05)}
.logo__text{
  font-family:var(--ff-d);font-size:1.2rem;font-weight:500;
  letter-spacing:-.01em;color:var(--ink);
}

/* Nav pills */
.nav-desktop{display:flex;align-items:center;gap:var(--sp-1)}
.nav__menu{display:flex;align-items:center;gap:2px}
.nav__link{
  padding:7px 16px;border-radius:var(--r-full);
  font-size:.78rem;font-weight:600;color:var(--ink-40);
  letter-spacing:.02em;transition:all var(--dur) var(--ease);
}
.nav__link:hover{color:var(--ink);background:var(--ink-05)}
.nav__link.active{color:var(--terra);background:var(--terra-wash)}

.header__actions{display:flex;align-items:center;gap:var(--sp-2);margin-left:var(--sp-4)}

/* Social circles — small with colored hover */
.social-btn{
  width:34px;height:34px;display:grid;place-items:center;
  border-radius:var(--r-full);background:var(--ink-05);color:var(--ink-40);
  transition:all var(--dur) var(--ease);
}
.social-btn svg{width:14px;height:14px}
.social-btn:hover{transform:translateY(-2px)}
.social-btn--whatsapp:hover{background:var(--wa);color:#fff;box-shadow:0 4px 16px rgba(37,211,102,.25)}
.social-btn--telegram:hover{background:var(--tg);color:#fff;box-shadow:0 4px 16px rgba(0,136,204,.25)}

/* Burger — rounded square */
.menu-toggle{
  display:none;width:42px;height:42px;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  background:var(--ink-05);border-radius:var(--r-sm);
  position:relative;z-index:1050;
  transition:background var(--dur) var(--ease);
}
.menu-toggle:hover{background:var(--ink-10)}
.menu-toggle span{display:block;width:18px;height:1.5px;background:var(--ink);border-radius:2px;transition:all .3s var(--ease-out);transform-origin:center}

/* Mobile nav — side panel from right */
.mobile-nav{
  display:none;position:fixed;top:0;right:0;bottom:0;z-index:1040;
  width:min(320px, 85vw);
  background:var(--white);
  box-shadow:-8px 0 40px rgba(44,41,38,.1);
  overflow-y:auto;
  transform:translateX(100%);
  transition:transform .35s var(--ease-out);
}
.mobile-nav.active{transform:translateX(0)}

/* Overlay behind panel */
.mobile-nav-overlay{
  display:none;position:fixed;inset:0;z-index:1039;
  background:rgba(44,41,38,.25);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  opacity:0;visibility:hidden;
  transition:opacity .3s var(--ease),visibility .3s;
}
.mobile-nav-overlay.active{opacity:1;visibility:visible}

/* Close button */
.mobile-nav__close{
  position:absolute;top:var(--sp-4);right:var(--sp-4);
  width:40px;height:40px;display:grid;place-items:center;
  background:var(--cream);border:1.5px solid var(--bd);border-radius:var(--r-sm);
  color:var(--ink-40);cursor:pointer;z-index:5;
  transition:all var(--dur) var(--ease);
}
.mobile-nav__close:hover{color:var(--terra);border-color:var(--terra-glow);background:var(--terra-wash)}
.mobile-nav__close svg{width:18px;height:18px}

/* Inner content */
.mobile-nav__inner{
  display:flex;flex-direction:column;
  padding:var(--sp-20) var(--sp-6) var(--sp-8);min-height:100%;
}

/* Logo inside mobile menu */
.mobile-nav__brand{
  display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-10);
}
.mobile-nav__brand .logo__mark{
  width:32px;height:32px;font-size:.75rem;
}
.mobile-nav__brand .logo__text{
  font-family:var(--ff-d);font-size:1.1rem;font-weight:400;color:var(--ink);
  font-variation-settings:'opsz' 48;
}

/* Menu links */
.mobile-nav__menu{display:flex;flex-direction:column;gap:2px;width:100%;margin-bottom:var(--sp-8)}
.mobile-nav__link{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--sp-4) var(--sp-4);
  border-radius:var(--r-sm);
  font-size:.95rem;font-weight:600;color:var(--ink-40);
  transition:all var(--dur) var(--ease);
}
.mobile-nav__link::after{
  content:'';width:6px;height:6px;border-right:1.5px solid var(--ink-10);
  border-bottom:1.5px solid var(--ink-10);transform:rotate(-45deg);
  transition:all var(--dur) var(--ease);
}
.mobile-nav__link:hover{color:var(--ink);background:var(--cream)}
.mobile-nav__link:hover::after{border-color:var(--ink-40)}
.mobile-nav__link.active{
  color:var(--terra);background:var(--terra-wash);
}
.mobile-nav__link.active::after{border-color:var(--terra)}

/* Divider */
.mobile-nav__divider{width:100%;height:1px;background:var(--bd);margin-bottom:var(--sp-6)}

/* Social buttons */
.mobile-nav__actions{display:flex;flex-direction:column;gap:var(--sp-2);width:100%;margin-top:auto}
.mobile-nav__social{
  display:flex;align-items:center;gap:var(--sp-3);
  padding:var(--sp-3) var(--sp-4);border-radius:var(--r-sm);font-size:.85rem;font-weight:700;
  text-decoration:none;transition:all var(--dur) var(--ease);
}
.mobile-nav__social svg{width:18px;height:18px;flex-shrink:0}
.mobile-nav__social--wa{color:var(--wa);background:rgba(37,211,102,.06)}
.mobile-nav__social--wa:hover{background:var(--wa);color:#fff}
.mobile-nav__social--tg{color:var(--tg);background:rgba(0,136,204,.06)}
.mobile-nav__social--tg:hover{background:var(--tg);color:#fff}


/* ================================================================
   MAIN
   ================================================================ */
.main{position:relative;z-index:1;padding-top:calc(var(--hdr-h) + var(--sp-4));min-height:100dvh;padding-bottom:var(--sp-16)}
.main>.container{padding-top:var(--sp-6)}


/* ================================================================
   STORIES — horizontal cards with rounded-rect frames
   ================================================================ */
.stories{margin-bottom:var(--sp-8)}
.stories__label{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 14px;background:var(--terra-wash);border-radius:var(--r-full);
  font-size:.6rem;font-weight:800;color:var(--terra);
  text-transform:uppercase;letter-spacing:.15em;margin-bottom:var(--sp-4);
}
.stories__label svg{width:8px;height:8px}

.stories__wrapper{overflow:hidden;margin-inline:calc(var(--sp-5)*-1)}
.stories__container{
  display:flex;gap:var(--sp-3);overflow-x:auto;padding:var(--sp-2) var(--sp-5);
  scrollbar-width:none;-webkit-overflow-scrolling:touch;cursor:grab;user-select:none;
  scroll-snap-type:x proximity;
}
.stories__container::-webkit-scrollbar{display:none}
.stories__container:active{cursor:grabbing}

.story{
  flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:6px;
  scroll-snap-align:start;transition:transform var(--dur) var(--ease-spring);
}
.story:hover{transform:translateY(-4px)}

/* Rounded rect instead of circle */
.story__ring{
  position:relative;width:68px;height:88px;border-radius:var(--r-lg);
  background:linear-gradient(145deg,var(--terra),var(--terra-dark));
  padding:2.5px;
  box-shadow:0 2px 10px rgba(198,125,91,.2);
  transition:box-shadow var(--dur) var(--ease);
}
.story:hover .story__ring{box-shadow:0 6px 20px rgba(198,125,91,.3)}

.story__avatar{
  width:100%;height:100%;border-radius:calc(var(--r-lg) - 2px);
  overflow:hidden;background:var(--cream-dark);
}
.story__avatar img{width:100%;height:100%;object-fit:cover;pointer-events:none}

.story__badge{
  position:absolute;bottom:-4px;right:-4px;width:20px;height:20px;
  display:grid;place-items:center;background:var(--white);
  border:2px solid var(--terra);border-radius:var(--r-full);
  box-shadow:0 2px 6px rgba(198,125,91,.25);
}
.story__badge svg{width:6px;height:6px;color:var(--terra)}

.story__name{
  max-width:68px;font-size:.6rem;font-weight:600;color:var(--ink-40);
  text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:color var(--dur) var(--ease);
}
.story:hover .story__name{color:var(--ink-70)}


/* ================================================================
   HERO — split layout: text left, showcase right
   ================================================================ */
.hero{
  display:grid;grid-template-columns:1fr 1fr;align-items:center;
  gap:var(--sp-10);padding:var(--sp-14) 0 var(--sp-16);
  position:relative;min-height:420px;
}

/* Left: text */
.hero__content{position:relative;z-index:2}

.hero__badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 16px;background:var(--terra);
  border-radius:var(--r-xs);
  font-size:.58rem;font-weight:800;color:#fff;
  text-transform:uppercase;letter-spacing:.15em;
  margin-bottom:var(--sp-6);
}

.hero__title{
  font-family:var(--ff-d);font-size:clamp(2.2rem,5vw,4.2rem);
  font-weight:300;line-height:1.05;letter-spacing:-.02em;
  color:var(--ink);margin-bottom:var(--sp-5);
  font-variation-settings:'opsz' 144;
}
.hero__title em{
  display:block;color:var(--terra);font-style:italic;font-weight:400;
  font-size:.5em;margin-top:var(--sp-2);letter-spacing:.01em;
  font-variation-settings:'opsz' 32;
}

.hero__desc{
  max-width:420px;
  font-size:.9rem;font-weight:400;color:var(--ink-40);line-height:1.85;
  margin-bottom:var(--sp-8);
}

.hero__cta{display:flex;gap:var(--sp-3);flex-wrap:wrap;margin-bottom:var(--sp-10)}
.hero__cta .btn{padding:13px 28px;font-size:.78rem}

/* Stats inline */
.hero__stats{display:flex;gap:var(--sp-8);flex-wrap:wrap}
.hero__stat{position:relative}
.hero__stat+.hero__stat::before{
  content:'';position:absolute;left:calc(var(--sp-8)/-2);top:20%;height:60%;
  width:1px;background:var(--bd);
}
.hero__stat-value{
  font-family:var(--ff-d);font-size:1.8rem;font-weight:400;
  color:var(--ink);line-height:1;font-variation-settings:'opsz' 72;
}
.hero__stat-label{
  font-size:.52rem;font-weight:700;color:var(--ink-20);
  text-transform:uppercase;letter-spacing:.14em;margin-top:2px;
}

/* Right: showcase — 3 overlapping tilted photos */
.hero__showcase{
  position:relative;height:440px;display:flex;align-items:center;justify-content:center;
}

.hero__card{
  position:absolute;width:200px;aspect-ratio:3/4;
  border-radius:var(--r-xl);overflow:hidden;
  box-shadow:0 16px 48px rgba(44,41,38,.15);
  border:3px solid var(--white);
  transition:transform .5s var(--ease-out),box-shadow .4s var(--ease);
}
.hero__card img{width:100%;height:100%;object-fit:cover;display:block}

.hero__card:nth-child(1){
  z-index:1;transform:rotate(-8deg) translate(-60px,20px);
}
.hero__card:nth-child(2){
  z-index:3;transform:rotate(0deg) translate(0,-10px) scale(1.08);
  box-shadow:0 20px 60px rgba(44,41,38,.2);
}
.hero__card:nth-child(3){
  z-index:2;transform:rotate(7deg) translate(60px,25px);
}

.hero__showcase:hover .hero__card:nth-child(1){transform:rotate(-12deg) translate(-75px,15px)}
.hero__showcase:hover .hero__card:nth-child(2){transform:rotate(2deg) translate(0,-20px) scale(1.1)}
.hero__showcase:hover .hero__card:nth-child(3){transform:rotate(10deg) translate(75px,20px)}

.hero__card-name{
  position:absolute;bottom:0;left:0;right:0;
  padding:var(--sp-6) var(--sp-3) var(--sp-3);
  background:linear-gradient(transparent,rgba(0,0,0,.5));
  font-family:var(--ff-d);font-size:.85rem;font-weight:500;color:#fff;
  text-align:center;pointer-events:none;
  font-variation-settings:'opsz' 32;
}

/* Decorative blob behind showcase */
.hero__showcase::before{
  content:'';position:absolute;
  width:320px;height:320px;border-radius:var(--r-full);
  background:radial-gradient(circle,var(--terra-wash) 0%,transparent 70%);
  filter:blur(40px);z-index:0;
}
.hero__showcase::after{
  content:'';position:absolute;top:10%;right:0;
  width:160px;height:160px;border-radius:var(--r-full);
  background:var(--sage-wash);filter:blur(35px);z-index:0;
}

/* Mobile: stack vertically */
@media(max-width:767px){
  .hero{
    grid-template-columns:1fr;gap:var(--sp-6);
    padding:var(--sp-8) 0 var(--sp-10);text-align:center;
  }
  .hero__content{order:2}
  .hero__desc{max-width:100%;margin-inline:auto}
  .hero__cta{justify-content:center}
  .hero__stats{justify-content:center}

  .hero__showcase{order:1;height:260px}
  .hero__card{width:130px}
  .hero__card:nth-child(1){transform:rotate(-8deg) translate(-40px,12px)}
  .hero__card:nth-child(2){transform:rotate(0deg) translate(0,-6px) scale(1.06)}
  .hero__card:nth-child(3){transform:rotate(7deg) translate(40px,14px)}
  .hero__showcase::before{width:220px;height:220px}
}
@media(min-width:768px) and (max-width:1023px){
  .hero{gap:var(--sp-6)}
  .hero__showcase{height:360px}
  .hero__card{width:160px}
}


/* ================================================================
   FILTER BAR — inline tags + compact selects
   ================================================================ */
.filter-bar{
  margin-bottom:var(--sp-6);padding:0;background:none;border:none;
}
/* Two rows: selects on top, chips + actions below */
.filter-bar__row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}

.filter-select{position:relative;flex:0 0 auto}
.filter-select__input{
  padding:9px 30px 9px 14px;
  background:var(--white);border:1.5px solid var(--bd);border-radius:var(--r-sm);
  color:var(--ink);font-size:.76rem;font-weight:600;cursor:pointer;
  -webkit-appearance:none;appearance:none;
  transition:all var(--dur) var(--ease);
}
.filter-select__input:hover{border-color:var(--bd-3);box-shadow:var(--sh-xs)}
.filter-select__input:focus{border-color:var(--terra);outline:none;box-shadow:0 0 0 3px var(--terra-wash)}
.filter-select__input option{background:var(--white)}
.filter-select::after{
  content:'';position:absolute;right:11px;top:50%;transform:translateY(-50%) rotate(45deg);
  width:5px;height:5px;border-right:1.5px solid var(--ink-20);border-bottom:1.5px solid var(--ink-20);
  pointer-events:none;
}

.filter-divider{width:1px;height:20px;background:var(--bd);flex-shrink:0;margin:0 2px}

.filter-chips{display:flex;gap:5px;flex-shrink:0}
.filter-chip{
  display:flex;align-items:center;gap:4px;padding:9px 14px;
  background:var(--white);border:1.5px solid var(--bd);
  border-radius:var(--r-sm);color:var(--ink-40);font-size:.76rem;font-weight:600;
  cursor:pointer;user-select:none;white-space:nowrap;
  transition:all var(--dur) var(--ease);
}
.filter-chip svg{width:9px;height:9px}
.filter-chip input{display:none}
.filter-chip:hover{border-color:var(--bd-3);color:var(--ink)}
.filter-chip.active{background:var(--terra);border-color:var(--terra);color:#fff}

.filter-more{
  display:flex;align-items:center;gap:4px;padding:9px 14px;
  background:var(--cream);border:1.5px solid var(--bd);border-radius:var(--r-sm);
  color:var(--ink-40);font-size:.76rem;font-weight:600;
  transition:all var(--dur) var(--ease);white-space:nowrap;flex-shrink:0;
}
.filter-more svg{width:13px;height:13px}
.filter-more:hover{border-color:var(--terra);color:var(--terra)}
.filter-more__count{
  background:var(--terra);color:#fff;font-size:.5rem;font-weight:800;
  width:16px;height:16px;display:grid;place-items:center;
  border-radius:var(--r-full);margin-left:2px;
}

.filter-actions{display:flex;gap:5px;flex-shrink:0;margin-left:auto}


/* ================================================================
   BUTTONS
   ================================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);
  padding:9px 20px;border-radius:var(--r-sm);
  font-size:.76rem;font-weight:700;white-space:nowrap;letter-spacing:.02em;text-transform:uppercase;
  cursor:pointer;transition:all var(--dur) var(--ease);
}
.btn--primary{
  background:var(--terra);color:var(--white);border:1.5px solid var(--terra);
  box-shadow:0 2px 8px rgba(198,125,91,.18);
}
.btn--primary:hover{background:var(--terra-dark);border-color:var(--terra-dark);box-shadow:0 6px 20px rgba(198,125,91,.25);transform:translateY(-1px)}
.btn--ghost{background:var(--white);border:1.5px solid var(--bd);color:var(--ink-40)}
.btn--ghost:hover{border-color:var(--ink-20);color:var(--ink)}


/* ================================================================
   RESULTS — with sort/view toggle area
   ================================================================ */
.results-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-5)}
.results-count{font-size:.78rem;color:var(--ink-40)}
.results-count strong{color:var(--ink);font-weight:700}


/* ================================================================
   CARDS GRID — magazine cover style, full-bleed image
   ================================================================ */
.cards-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:var(--sp-4);
}

.card{
  position:relative;
  border-radius:var(--r-xl);overflow:hidden;
  aspect-ratio:3/4;
  cursor:pointer;
  box-shadow:var(--sh-sm);
  transition:transform var(--dur-slow) var(--ease-out),box-shadow var(--dur-slow) var(--ease);
}
.card:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--sh-xl)}

.card__link{display:block;position:absolute;inset:0;z-index:1;color:inherit}

.card__image{position:absolute;inset:0;overflow:hidden;background:var(--cream-deep)}
.card__image img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out),filter .4s var(--ease)}
.card:hover .card__image img{transform:scale(1.08);filter:brightness(1.02)}

/* gradient: top for badges, bottom for text */
.card__overlay{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.15) 0%, transparent 25%,transparent 45%, rgba(0,0,0,.55) 100%);
  transition:opacity var(--dur) var(--ease);
}

/* badges — top left */
.card__badges{position:absolute;top:var(--sp-3);left:var(--sp-3);display:flex;flex-wrap:wrap;gap:4px;z-index:4}
.badge{
  padding:4px 10px;border-radius:var(--r-xs);font-size:.55rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.06em;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.badge--video{display:flex;align-items:center;gap:3px;background:rgba(0,0,0,.4);color:#fff}
.badge--video svg{width:6px;height:6px}
.badge--new{background:var(--terra);color:#fff}

/* price tag — top right, angled */
.card__price{
  position:absolute;top:var(--sp-3);right:var(--sp-3);z-index:4;
  padding:5px 12px;
  background:var(--white);border-radius:var(--r-xs);
  font-size:.68rem;font-weight:800;color:var(--ink);letter-spacing:.02em;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
  transition:all var(--dur) var(--ease);
}
.card:hover .card__price{background:var(--terra);color:#fff}

/* text overlay — bottom */
.card__info{
  position:absolute;bottom:0;left:0;right:0;z-index:3;
  padding:var(--sp-14) var(--sp-4) var(--sp-4);
  pointer-events:none;
}
.card__title{
  font-family:var(--ff-d);font-size:1.15rem;font-weight:500;
  font-variation-settings:'opsz' 48;color:#fff;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-bottom:2px;
  text-shadow:0 1px 6px rgba(0,0,0,.3);
}
.card__meta{
  display:flex;align-items:center;gap:4px;
  font-size:.68rem;font-weight:500;color:rgba(255,255,255,.7);
}
.card__meta svg{width:10px;height:10px;color:rgba(255,255,255,.5);flex-shrink:0}

/* socials — slide up from bottom on hover */
.card__socials{
  position:absolute;bottom:0;left:0;right:0;z-index:5;
  display:flex;gap:6px;padding:var(--sp-3);
  transform:translateY(100%);opacity:0;
  transition:transform .3s var(--ease-out),opacity .2s var(--ease);
}
.card:hover .card__socials{transform:translateY(0);opacity:1}

.card__social-btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:5px;
  padding:10px 8px;border-radius:var(--r-sm);font-size:.68rem;font-weight:700;
  text-decoration:none;color:#fff;
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  transition:all var(--dur) var(--ease);
}
.card__social-btn svg{width:14px;height:14px;flex-shrink:0}
.card__social-btn--whatsapp{background:rgba(37,211,102,.85)}
.card__social-btn--whatsapp:hover{background:var(--wa);box-shadow:0 4px 16px rgba(37,211,102,.4)}
.card__social-btn--telegram{background:rgba(0,136,204,.85)}
.card__social-btn--telegram:hover{background:var(--tg);box-shadow:0 4px 16px rgba(0,136,204,.4)}

/* VIP indicator — glowing left border */
.card--vip{border:2px solid rgba(212,175,55,.35)}
.card--vip::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:3px;
  background:linear-gradient(180deg,#D4AF37,#F5D060,#D4AF37);
  z-index:6;border-radius:var(--r-xl) 0 0 var(--r-xl);
  box-shadow:0 0 12px rgba(212,175,55,.3);
}
/* hidden: old absolute badge kept for backwards compat, visually replaced by badge--premium */
.card__vip-badge{display:none}

/* Premium badge inside card__badges */
.badge--premium{
  display:flex;align-items:center;gap:4px;
  background:linear-gradient(135deg,#D4AF37,#F5D060);
  color:#3D2E00;
  box-shadow:0 2px 8px rgba(212,175,55,.35);
}
.badge--premium svg{width:10px;height:10px}


/* ================================================================
   PROMISE SECTION — icon cards on cream bg
   ================================================================ */
.promise{padding:var(--sp-24) 0;position:relative}
.promise::before{
  content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,var(--bd),transparent);
}

.promise__header{text-align:center;margin-bottom:var(--sp-14)}
.promise__eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.6rem;font-weight:800;color:var(--terra);
  text-transform:uppercase;letter-spacing:.2em;margin-bottom:var(--sp-3);
}
.promise__title{
  font-family:var(--ff-d);font-size:clamp(1.5rem,3.5vw,2.6rem);
  font-weight:300;color:var(--ink);font-variation-settings:'opsz' 72;
}

.promise__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5)}
.promise__card{
  padding:var(--sp-10) var(--sp-6);text-align:center;
  background:var(--white);border:1px solid var(--bd);border-radius:var(--r-2xl);
  box-shadow:var(--sh-xs);position:relative;overflow:hidden;
  transition:transform var(--dur-slow) var(--ease-out),box-shadow var(--dur-slow) var(--ease);
}
.promise__card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}

.promise__icon{
  width:64px;height:64px;margin:0 auto var(--sp-5);
  display:grid;place-items:center;
  background:var(--terra-wash);border-radius:var(--r-lg);color:var(--terra);
  transition:all var(--dur) var(--ease);
}
.promise__icon svg{width:26px;height:26px}
.promise__card:hover .promise__icon{background:var(--terra);color:#fff;border-radius:var(--r-full);box-shadow:0 6px 24px rgba(198,125,91,.25)}

.promise__card-title{
  font-family:var(--ff-d);font-size:1.1rem;font-weight:500;
  font-variation-settings:'opsz' 48;margin-bottom:var(--sp-2);
}
.promise__card-text{font-size:.82rem;color:var(--ink-40);line-height:1.75}


/* ================================================================
   EXPERIENCE STEPS — connected circles
   ================================================================ */
.experience{padding:var(--sp-20) 0;position:relative}
.experience::before{
  content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,var(--bd),transparent);
}

.experience__header{text-align:center;margin-bottom:var(--sp-14)}
.experience__eyebrow{font-size:.6rem;font-weight:800;color:var(--sage);text-transform:uppercase;letter-spacing:.2em;margin-bottom:var(--sp-3)}
.experience__title{
  font-family:var(--ff-d);font-size:clamp(1.5rem,3.5vw,2.6rem);
  font-weight:300;color:var(--ink);font-variation-settings:'opsz' 72;
}

.experience__steps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6);max-width:920px;margin:0 auto;position:relative}
/* connecting line */
.experience__steps::before{content:'';position:absolute;top:36px;left:calc(16.67% + 36px);right:calc(16.67% + 36px);height:2px;background:var(--cream-deep);border-radius:1px}

.exp-step{text-align:center;position:relative}
.exp-step__num{
  width:72px;height:72px;margin:0 auto var(--sp-5);
  display:grid;place-items:center;
  background:var(--white);border:2px solid var(--cream-deep);border-radius:var(--r-full);
  font-family:var(--ff-d);font-size:1.5rem;font-weight:400;color:var(--terra);
  font-variation-settings:'opsz' 72;
  position:relative;z-index:2;
  box-shadow:var(--sh-sm);
  transition:all var(--dur) var(--ease);
}
.exp-step:hover .exp-step__num{
  background:var(--terra);color:#fff;border-color:var(--terra);
  box-shadow:0 6px 24px rgba(198,125,91,.25);transform:scale(1.08);
}

.exp-step__title{
  font-family:var(--ff-d);font-size:1rem;font-weight:500;
  font-variation-settings:'opsz' 48;margin-bottom:var(--sp-2);
}
.exp-step__text{font-size:.8rem;color:var(--ink-40);line-height:1.75;max-width:240px;margin:0 auto}


/* ================================================================
   MARQUEE
   ================================================================ */
.marquee-section{padding:var(--sp-10) 0;overflow:hidden;border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);background:var(--white)}
.marquee{display:flex;gap:var(--sp-12);animation:marquee-scroll 30s linear infinite;white-space:nowrap}
.marquee__item{display:flex;align-items:center;gap:var(--sp-3);flex-shrink:0}
.marquee__val{font-family:var(--ff-d);font-size:1.8rem;font-weight:400;color:var(--ink);font-variation-settings:'opsz' 72}
.marquee__lbl{font-size:.55rem;font-weight:700;color:var(--ink-20);text-transform:uppercase;letter-spacing:.15em}
.marquee__dot{width:5px;height:5px;border-radius:var(--r-full);background:var(--terra);opacity:.35;flex-shrink:0}
@keyframes marquee-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}


/* ================================================================
   LOADING / EMPTY / END
   ================================================================ */
.loading{display:flex;flex-direction:column;align-items:center;padding:var(--sp-16) 0;gap:var(--sp-3)}
.loading__spinner{width:28px;height:28px;border:2px solid var(--bd);border-top-color:var(--terra);border-radius:var(--r-full);animation:spin .5s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading__text{color:var(--ink-20);font-size:.8rem}

.no-results{text-align:center;padding:var(--sp-24);background:var(--white);border:1px solid var(--bd);border-radius:var(--r-2xl);box-shadow:var(--sh-sm)}
.no-results__icon{width:40px;height:40px;margin:0 auto var(--sp-4);color:var(--ink-20);opacity:.4}
.no-results__title{font-family:var(--ff-d);font-size:1.15rem;font-weight:400;margin-bottom:var(--sp-2)}
.no-results__text{color:var(--ink-40);font-size:.85rem}

.end-message{text-align:center;padding:var(--sp-8) 0;color:var(--ink-20);font-size:.7rem;letter-spacing:.15em;font-weight:700;text-transform:uppercase}


/* ================================================================
   MODALS
   ================================================================ */
.modal{position:fixed;inset:0;z-index:2000;display:none;align-items:center;justify-content:center;padding:var(--sp-4)}
.modal.active{display:flex}
.modal__overlay{position:absolute;inset:0;background:rgba(44,41,38,.3);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}
.modal__content{
  position:relative;width:100%;max-width:400px;max-height:90dvh;
  background:var(--white);border:1px solid var(--bd);border-radius:var(--r-2xl);
  overflow:hidden;box-shadow:var(--sh-xl);
  transform:scale(.94) translateY(20px);opacity:0;
  transition:transform .35s var(--ease-spring),opacity var(--dur) var(--ease);
}
.modal.active .modal__content{transform:scale(1) translateY(0);opacity:1}

.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--bd)}
.modal__title{font-family:var(--ff-d);font-size:1rem;font-weight:500;font-variation-settings:'opsz' 48}
.modal__close{
  width:34px;height:34px;display:grid;place-items:center;
  background:var(--ink-05);border-radius:var(--r-full);color:var(--ink-40);
  transition:all var(--dur) var(--ease);
}
.modal__close:hover{background:var(--terra);color:#fff}
.modal__close svg{width:14px;height:14px}

.modal__body{padding:var(--sp-6);overflow-y:auto;max-height:calc(90dvh - 130px)}
.modal__group{margin-bottom:var(--sp-5)}
.modal__label{display:block;font-size:.65rem;font-weight:700;color:var(--ink-40);margin-bottom:var(--sp-2);text-transform:uppercase;letter-spacing:.1em}
.modal__range{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
.modal__input{
  width:100%;padding:var(--sp-3) var(--sp-4);background:var(--cream);
  border:1px solid transparent;border-radius:var(--r-sm);color:var(--ink);
  transition:all var(--dur) var(--ease);
}
.modal__input::placeholder{color:var(--ink-20)}
.modal__input:focus{outline:none;border-color:var(--terra);background:var(--white);box-shadow:0 0 0 3px var(--terra-wash)}
.modal__footer{display:flex;gap:var(--sp-3);padding:var(--sp-5) var(--sp-6);border-top:1px solid var(--bd)}
.modal__footer .btn{flex:1}


/* ================================================================
   FOOTER — light, warm
   ================================================================ */
.footer{
  background:var(--white);border-top:1px solid var(--bd);
  padding:var(--sp-20) 0 var(--sp-10);margin-top:var(--sp-20);
}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:var(--sp-10);margin-bottom:var(--sp-12)}
.footer__col-title{
  font-family:var(--ff-d);font-size:1rem;font-weight:500;font-variation-settings:'opsz' 48;
  margin-bottom:var(--sp-4);color:var(--ink);
}
.footer__about-text{color:var(--ink-40);font-size:.85rem;line-height:1.8;margin-bottom:var(--sp-5)}
.footer__socials{display:flex;gap:var(--sp-2)}

.footer__links li{margin-bottom:var(--sp-3)}
.footer__links a{color:var(--ink-40);font-size:.85rem;transition:color var(--dur) var(--ease)}
.footer__links a:hover{color:var(--terra)}

.footer__contact li{display:flex;align-items:flex-start;gap:var(--sp-3);margin-bottom:var(--sp-4);color:var(--ink-40);font-size:.85rem}
.footer__contact li svg{width:14px;height:14px;color:var(--terra);flex-shrink:0;margin-top:3px}
.footer__contact a{color:var(--ink-40);transition:color var(--dur) var(--ease)}
.footer__contact a:hover{color:var(--terra)}

.footer__bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:var(--sp-6);border-top:1px solid var(--bd);flex-wrap:wrap;gap:var(--sp-3);
}
.footer__copyright{color:var(--ink-20);font-size:.72rem}
.footer__copyright a{color:var(--terra);transition:opacity var(--dur) var(--ease)}
.footer__copyright a:hover{opacity:.7}
.footer__bottom-links{display:flex;gap:var(--sp-6)}
.footer__bottom-links a{color:var(--ink-20);font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;transition:color var(--dur) var(--ease)}
.footer__bottom-links a:hover{color:var(--terra)}


/* ================================================================
   SCROLL TOP
   ================================================================ */
.scroll-top{
  position:fixed;bottom:var(--sp-6);right:var(--sp-6);
  width:44px;height:44px;display:grid;place-items:center;
  background:var(--terra);border-radius:var(--r-full);color:#fff;
  z-index:900;opacity:0;visibility:hidden;transform:translateY(16px);
  box-shadow:0 4px 20px rgba(198,125,91,.3);
  transition:all var(--dur-slow) var(--ease);
}
.scroll-top svg{width:18px;height:18px}
.scroll-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.scroll-top:hover{transform:translateY(-3px) scale(1.08)}


/* ================================================================
   ANIMATIONS
   ================================================================ */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

.cards-grid .card{opacity:0;animation:fadeUp .5s var(--ease-out) forwards}
.cards-grid .card:nth-child(1){animation-delay:.03s}.cards-grid .card:nth-child(2){animation-delay:.08s}
.cards-grid .card:nth-child(3){animation-delay:.13s}.cards-grid .card:nth-child(4){animation-delay:.18s}
.cards-grid .card:nth-child(5){animation-delay:.23s}.cards-grid .card:nth-child(6){animation-delay:.28s}
.cards-grid .card:nth-child(7){animation-delay:.33s}.cards-grid .card:nth-child(8){animation-delay:.38s}
.cards-grid .card:nth-child(9){animation-delay:.43s}.cards-grid .card:nth-child(10){animation-delay:.48s}
.cards-grid .card:nth-child(11){animation-delay:.53s}.cards-grid .card:nth-child(12){animation-delay:.58s}

.hero__content{animation:fadeUp .6s var(--ease-out) both;animation-delay:.1s}
.hero__showcase .hero__card{opacity:0;animation:fadeUp .5s var(--ease-out) forwards}
.hero__showcase .hero__card:nth-child(1){animation-delay:.2s}
.hero__showcase .hero__card:nth-child(2){animation-delay:.35s}
.hero__showcase .hero__card:nth-child(3){animation-delay:.5s}


/* ================================================================
   RESPONSIVE — TABLET
   ================================================================ */
@media(max-width:1279px){
  .cards-grid{grid-template-columns:repeat(3,1fr)}
  .footer__grid{grid-template-columns:repeat(2,1fr);gap:var(--sp-8)}
}
@media(max-width:1023px){
  .cards-grid{grid-template-columns:repeat(2,1fr);gap:var(--sp-3)}
  .card__socials{transform:translateY(0);opacity:1}
  .promise__grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .experience__steps{grid-template-columns:1fr;gap:var(--sp-5);max-width:340px}
  .experience__steps::before{display:none}
  .hero{padding:var(--sp-12) 0 var(--sp-14)}
  .filter-bar__row{flex-wrap:wrap}
}


/* ================================================================
   RESPONSIVE — MOBILE
   ================================================================ */
@media(max-width:767px){
  :root{--hdr-h:64px}
  .header{padding:var(--sp-2) var(--sp-3)}
  .header__bar{height:48px;padding:0 var(--sp-3) 0 var(--sp-4)}
  .logo__mark{width:30px;height:30px;font-size:.75rem;border-radius:var(--r-xs)}
  .logo__text{font-size:1.05rem}
  .nav-desktop{display:none!important}
  .menu-toggle{display:flex!important;z-index:1050!important}
  .mobile-nav{display:block}
  .mobile-nav-overlay{display:block}

  .main{padding-top:calc(var(--hdr-h) + var(--sp-2))}
  .main>.container{padding-top:var(--sp-4)}

  .stories{margin-bottom:var(--sp-5)}
  .stories__wrapper{margin-inline:calc(var(--sp-3)*-1)}
  .stories__container{gap:var(--sp-2);padding:var(--sp-1) var(--sp-3)}
  .story__ring{width:56px;height:72px;border-radius:var(--r-md)}
  .story__avatar{border-radius:calc(var(--r-md) - 2px)}
  .story__name{max-width:56px;font-size:.55rem}

  .hero{padding:var(--sp-10) 0 var(--sp-8)}
  .hero::before,.hero::after{display:none}
  .hero__badge{padding:6px 14px;font-size:.6rem}
  .hero__title{font-size:clamp(2rem,9vw,3.2rem)}
  .hero__desc{font-size:.85rem;margin-bottom:var(--sp-8)}
  .hero__stats{gap:var(--sp-2)}
  .hero__stat{padding:var(--sp-2) var(--sp-4)}
  .hero__stat-value{font-size:1.2rem}

  .filter-bar{margin-bottom:var(--sp-4)}
  .filter-bar__row{display:flex;flex-wrap:wrap;gap:5px}
  .filter-select__input{padding:8px 24px 8px 10px;font-size:.7rem}
  .filter-divider{display:none}
  .filter-chip{padding:8px 12px;font-size:.7rem}
  .filter-more{padding:8px 12px;font-size:.7rem}
  .filter-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:5px}
  .filter-actions .btn{padding:9px 12px;font-size:.7rem}

  .cards-grid{grid-template-columns:repeat(2,1fr);gap:var(--sp-2)}
  .card{border-radius:var(--r-lg)}
  .card:hover{transform:none;box-shadow:var(--sh-md)}
  /* on mobile socials always visible */
  .card__socials{transform:translateY(0);opacity:1}
  .card__info{padding:var(--sp-8) var(--sp-3) var(--sp-3)}
  .card__title{font-size:.88rem}
  .card__meta{font-size:.6rem}
  .card__price{font-size:.6rem;padding:3px 8px}
  .badge{font-size:.48rem;padding:3px 6px}
  .card__social-btn{padding:8px;font-size:.6rem}
  .card__social-btn svg{width:12px;height:12px}
  .card__social-btn span{display:none}

  .promise{padding:var(--sp-14) 0}
  .experience{padding:var(--sp-12) 0}
  .marquee__val{font-size:1.4rem}

  .footer{padding:var(--sp-12) 0 var(--sp-6);margin-top:var(--sp-12)}
  .footer__grid{grid-template-columns:1fr;gap:var(--sp-8);text-align:center}
  .footer__socials{justify-content:center}
  .footer__contact li{justify-content:center}
  .footer__bottom{flex-direction:column;text-align:center}

  .modal{align-items:flex-end;padding:0}
  .modal .modal__content{max-width:100%;border-radius:var(--r-2xl) var(--r-2xl) 0 0;transform:translateY(100%);opacity:1}
  .modal.active .modal__content{transform:translateY(0)}

  .scroll-top{bottom:var(--sp-4);right:var(--sp-4);width:40px;height:40px}
}

@media(max-width:374px){
  .filter-bar__row{grid-template-columns:1fr}
  .cards-grid{gap:var(--sp-2)}
  .hero__title{font-size:1.8rem}
  .hero__stats{flex-direction:column;align-items:center}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}


/* ================================================================
   PROFILE PAGE — Crème Design
   ================================================================ */
.profile-page{padding-bottom:var(--sp-8)}

.breadcrumbs{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-4) 0 var(--sp-3);font-size:.72rem;color:var(--ink-20)}
.breadcrumbs a{color:var(--ink-40);transition:color var(--dur) var(--ease)}
.breadcrumbs a:hover{color:var(--terra)}
.breadcrumbs .sep{opacity:.3}
.breadcrumbs .sep svg{vertical-align:middle}
.breadcrumbs .current{color:var(--ink);font-weight:600;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.profile-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-5)}
.pn-btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);border-radius:var(--r-sm);font-size:.78rem;font-weight:600;color:var(--ink-40);background:var(--white);border:1.5px solid var(--bd);transition:all var(--dur) var(--ease)}
.pn-btn svg{width:16px;height:16px}
.pn-btn:hover{color:var(--terra);border-color:var(--terra-glow);background:var(--terra-wash)}
.pn-arrows{display:flex;gap:var(--sp-2)}
.pn-btn--arrow{width:38px;height:38px;justify-content:center;padding:0;border-radius:var(--r-sm)}

/* Layout */
.profile-layout{display:grid;grid-template-columns:1fr;gap:var(--sp-6);align-items:start}
@media(min-width:768px){.profile-layout{grid-template-columns:1fr 1fr;gap:var(--sp-6)}}
@media(min-width:1024px){.profile-layout{grid-template-columns:440px 1fr;gap:var(--sp-8)}}
@media(min-width:1280px){.profile-layout{grid-template-columns:500px 1fr;gap:var(--sp-10)}}

.profile-col-gallery{position:relative}
@media(min-width:768px){.profile-col-gallery{position:sticky;top:calc(var(--hdr-h) + var(--sp-4));align-self:start}}

/* ─── Gallery ─── */
.profile-gallery{position:relative;border-radius:var(--r-xl);overflow:hidden;background:var(--cream-dark);border:1px solid var(--bd);box-shadow:var(--sh-md)}

.pg-badges{position:absolute;top:var(--sp-3);left:var(--sp-3);display:flex;gap:var(--sp-2);z-index:10}
.pg-badge{
  display:inline-flex;align-items:center;gap:4px;padding:5px 12px;
  border-radius:var(--r-xs);font-size:.58rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.06em;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.pg-badge--vip{
  background:linear-gradient(135deg,#D4AF37,#F5D060);color:#3D2E00;
  box-shadow:0 2px 8px rgba(212,175,55,.3);
}
.pg-badge--vip svg{width:10px;height:10px}
.pg-badge--video{background:rgba(0,0,0,.45);color:#fff}
.pg-badge--video svg{width:8px;height:8px}

.pg-viewport{aspect-ratio:3/4;position:relative;cursor:pointer}
.pg-current{width:100%;height:100%}
.pg-current img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.pg-current video{width:100%;height:100%;object-fit:contain;background:#000;display:block}

.pg-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:64px;height:64px;display:grid;place-items:center;border-radius:var(--r-full);
  background:rgba(255,255,255,.9);box-shadow:var(--sh-md);
  color:var(--terra);cursor:pointer;z-index:5;border:none;
  transition:all var(--dur) var(--ease);
}
.pg-play svg{width:24px;height:24px;margin-left:3px}
.pg-play:hover{background:var(--terra);color:#fff;transform:translate(-50%,-50%) scale(1.08)}
.pg-play.is-hidden{opacity:0;pointer-events:none;transform:translate(-50%,-50%) scale(.8)}

.pg-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:40px;height:40px;display:grid;place-items:center;border-radius:var(--r-sm);
  background:rgba(255,255,255,.9);box-shadow:var(--sh-sm);
  color:var(--ink);z-index:10;cursor:pointer;border:none;opacity:0;
  transition:all var(--dur) var(--ease);
}
.pg-arrow svg{width:16px;height:16px}
.profile-gallery:hover .pg-arrow{opacity:1}
.pg-arrow:hover{background:var(--terra);color:#fff}
.pg-arrow--prev{left:var(--sp-3)}.pg-arrow--next{right:var(--sp-3)}

.pg-counter{
  position:absolute;bottom:var(--sp-3);right:var(--sp-3);
  padding:5px 12px;background:rgba(255,255,255,.88);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  border-radius:var(--r-xs);font-size:.65rem;font-weight:700;color:var(--ink);z-index:10;
}
.pg-counter-sep{opacity:.3;margin:0 2px}

/* Thumbnail grid — 3:4 aspect ratio */
.pg-thumbs-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(58px,1fr));
  gap:var(--sp-2);margin-top:var(--sp-3);
}
.pg-thumb{
  position:relative;aspect-ratio:3/4;border-radius:var(--r-xs);overflow:hidden;
  border:2px solid transparent;opacity:.45;cursor:pointer;padding:0;background:none;
  transition:all var(--dur) var(--ease);
}
.pg-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.pg-thumb:hover{opacity:.7}
.pg-thumb.is-active{opacity:1;border-color:var(--terra);box-shadow:0 0 8px var(--terra-glow)}
.pg-thumb-play{
  position:absolute;inset:0;display:grid;place-items:center;
  background:rgba(0,0,0,.25);color:#fff;z-index:2;
}
.pg-thumb-play svg{width:12px;height:12px}

@media(min-width:1024px){
  .pg-thumbs-grid{grid-template-columns:repeat(auto-fill,minmax(68px,1fr))}
}


/* ─── Profile Info Cards ─── */
.p-card{
  background:var(--white);border:1.5px solid var(--bd);border-radius:var(--r-xl);
  padding:var(--sp-5);margin-bottom:var(--sp-4);
  box-shadow:var(--sh-xs);transition:border-color var(--dur) var(--ease);
}
.p-card:last-child{margin-bottom:0}
.p-card:hover{border-color:var(--bd-2)}

.p-card__title{
  display:flex;align-items:center;gap:var(--sp-2);
  font-family:var(--ff-d);font-size:.95rem;font-weight:500;font-variation-settings:'opsz' 48;
  color:var(--ink);margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--bd);
}
.p-card__title svg{width:17px;height:17px;color:var(--terra);flex-shrink:0}

/* Identity card */
.p-card--identity{border-color:var(--bd-2);background:var(--cream)}
.p-identity{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-3);flex-wrap:wrap;margin-bottom:var(--sp-5)}
.p-identity__top{flex:1;min-width:0}
.p-identity__name{
  font-family:var(--ff-d);font-size:clamp(1.4rem,3vw,2rem);font-weight:400;
  font-variation-settings:'opsz' 72;line-height:1.15;color:var(--ink);margin-bottom:var(--sp-1);
}
.p-identity__loc{display:flex;align-items:center;gap:var(--sp-1);font-size:.78rem;color:var(--ink-40)}
.p-identity__loc svg{width:14px;height:14px;color:var(--terra);flex-shrink:0}

.p-identity__price{
  display:flex;align-items:baseline;gap:3px;flex-shrink:0;
  padding:var(--sp-2) var(--sp-4);background:var(--terra);border-radius:var(--r-sm);
  box-shadow:0 4px 16px rgba(198,125,91,.2);
}
.p-identity__price-num{font-family:var(--ff-d);font-size:1.4rem;font-weight:400;color:#fff;line-height:1;font-variation-settings:'opsz' 72}
.p-identity__price-cur{font-size:.65rem;font-weight:700;color:rgba(255,255,255,.6)}
.p-identity__price-per{font-size:.55rem;color:rgba(255,255,255,.4);margin-left:1px}

.p-stats{
  display:flex;background:var(--white);border:1px solid var(--bd);border-radius:var(--r-sm);
  overflow:hidden;margin-bottom:var(--sp-5);
}
.p-stat{flex:1;text-align:center;padding:var(--sp-3) var(--sp-2);position:relative}
.p-stat+.p-stat::before{content:'';position:absolute;left:0;top:18%;height:64%;width:1px;background:var(--bd)}
.p-stat__val{display:block;font-family:var(--ff-d);font-size:1.15rem;font-weight:400;color:var(--ink);line-height:1.2;font-variation-settings:'opsz' 48}
.p-stat__val small{font-family:var(--ff-b);font-size:.55rem;font-weight:500;color:var(--ink-20);margin-left:1px}
.p-stat__lbl{font-size:.5rem;font-weight:700;color:var(--ink-20);text-transform:uppercase;letter-spacing:.14em;margin-top:2px}

.p-contacts{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
.p-contact{
  display:flex;align-items:center;justify-content:center;gap:var(--sp-2);
  padding:var(--sp-3);border-radius:var(--r-sm);font-size:.82rem;font-weight:600;
  text-decoration:none;transition:all var(--dur) var(--ease);
}
.p-contact svg{width:17px;height:17px;flex-shrink:0}
.p-contact--wa{background:rgba(37,211,102,.06);color:var(--wa);border:1.5px solid rgba(37,211,102,.12)}
.p-contact--wa:hover{background:var(--wa);color:#fff;border-color:var(--wa);box-shadow:0 4px 16px rgba(37,211,102,.25);transform:translateY(-2px)}
.p-contact--tg{background:rgba(0,136,204,.06);color:var(--tg);border:1.5px solid rgba(0,136,204,.12)}
.p-contact--tg:hover{background:var(--tg);color:#fff;border-color:var(--tg);box-shadow:0 4px 16px rgba(0,136,204,.25);transform:translateY(-2px)}


/* ─── Details ─── */
.p-details{display:flex;flex-direction:column}
.p-detail{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) 0;border-bottom:1px solid var(--bd)}
.p-detail:last-child{border-bottom:none;padding-bottom:0}
.p-detail:first-child{padding-top:0}
.p-detail dt{font-size:.78rem;color:var(--ink-40)}
.p-detail dd{font-size:.82rem;font-weight:600;color:var(--ink);text-align:right}


/* ─── UNIQUE: Availability Calendar ─── */
.p-card--availability{border-color:var(--sage-wash);background:linear-gradient(135deg,var(--white),rgba(139,154,126,.04))}
.p-card--availability .p-card__title svg{color:var(--sage)}
.p-avail{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--sp-2)}
.p-avail__day{
  text-align:center;padding:var(--sp-3) var(--sp-1);
  border-radius:var(--r-sm);background:var(--cream);border:1.5px solid var(--bd);
  transition:all var(--dur) var(--ease);
}
.p-avail__day.is-today{border-color:var(--terra);background:var(--terra-wash)}
.p-avail__day.is-available .p-avail__day-status svg{color:var(--sage)}
.p-avail__day:not(.is-available) .p-avail__day-status svg{color:var(--ink-10)}
.p-avail__day-name{
  display:block;font-size:.55rem;font-weight:800;color:var(--ink-40);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--sp-1);
}
.p-avail__day.is-today .p-avail__day-name{color:var(--terra)}
.p-avail__day-status{display:block}
.p-avail__day-status svg{width:16px;height:16px}


/* ─── Services ─── */
.p-services{display:flex;flex-wrap:wrap;gap:var(--sp-2)}
.p-service{
  display:inline-block;padding:5px 13px;background:var(--cream);
  border:1.5px solid var(--bd);border-radius:var(--r-xs);
  font-size:.72rem;font-weight:500;color:var(--ink-40);transition:all var(--dur) var(--ease);
}
.p-service:hover{border-color:var(--terra-glow);color:var(--terra);background:var(--terra-wash)}


/* ─── Prices Table ─── */
.p-prices__head{display:grid;grid-template-columns:1.3fr 1fr;gap:var(--sp-2);padding-bottom:var(--sp-3);border-bottom:1px solid var(--bd-2);margin-bottom:var(--sp-1)}
.p-prices--dual .p-prices__head,.p-prices--dual .p-prices__row{grid-template-columns:1.3fr 1fr 1fr}
.p-prices__head span{font-size:.55rem;font-weight:700;color:var(--ink-20);text-transform:uppercase;letter-spacing:.12em}
.p-prices__head span:not(:first-child){text-align:right}
.p-prices__row{display:grid;grid-template-columns:1.3fr 1fr;gap:var(--sp-2);padding:var(--sp-3) 0;border-bottom:1px solid var(--bd);transition:background var(--dur) var(--ease)}
.p-prices__row:last-child{border-bottom:none}
.p-prices__row--hl{background:var(--terra-wash);margin-inline:calc(var(--sp-3)*-1);padding-inline:var(--sp-3);border-radius:var(--r-xs);border-bottom-color:transparent}
.p-prices__dur{font-size:.8rem;font-weight:500;color:var(--ink-40)}
.p-prices__val{font-size:.82rem;font-weight:700;color:var(--ink);text-align:right}
.p-prices__val small{font-weight:500;color:var(--ink-20);font-size:.65rem}


/* ─── Hours ─── */
.p-card--compact{padding:var(--sp-4)}
.p-hours{display:flex;align-items:center;gap:var(--sp-3)}
.p-hours__icon{width:40px;height:40px;display:grid;place-items:center;background:var(--cream);border-radius:var(--r-sm);flex-shrink:0}
.p-hours__icon svg{width:17px;height:17px;color:var(--terra)}
.p-hours__lbl{display:block;font-size:.55rem;font-weight:700;color:var(--ink-20);text-transform:uppercase;letter-spacing:.12em}
.p-hours__val{display:block;font-size:.85rem;font-weight:600;color:var(--ink)}
.p-hours__dot{width:9px;height:9px;border-radius:var(--r-full);background:var(--ink-10);flex-shrink:0;margin-left:auto}
.p-hours__dot--on{background:#22c55e;box-shadow:0 0 8px rgba(34,197,94,.5);animation:pulse-status 2s ease-in-out infinite}
@keyframes pulse-status{0%,100%{box-shadow:0 0 8px rgba(34,197,94,.5)}50%{box-shadow:0 0 16px rgba(34,197,94,.8)}}


/* ─── Bottom Nav ─── */
.profile-bottom-nav{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);padding-top:var(--sp-8);margin-top:var(--sp-8);border-top:1px solid var(--bd)}
.pbn-card{
  display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4);
  background:var(--white);border:1.5px solid var(--bd);border-radius:var(--r-xl);
  text-decoration:none;box-shadow:var(--sh-xs);transition:all var(--dur) var(--ease);
}
.pbn-card:hover{border-color:var(--terra-glow);box-shadow:var(--sh-md);transform:translateY(-2px)}
.pbn-card--next{justify-content:flex-end;text-align:right}
.pbn-card__arr{width:36px;height:36px;display:grid;place-items:center;background:var(--cream);border-radius:var(--r-sm);flex-shrink:0;transition:all var(--dur) var(--ease)}
.pbn-card__arr svg{width:15px;height:15px;color:var(--ink-40)}
.pbn-card:hover .pbn-card__arr{background:var(--terra)}
.pbn-card:hover .pbn-card__arr svg{color:#fff}
.pbn-card__lbl{display:block;font-size:.52rem;font-weight:700;color:var(--ink-20);text-transform:uppercase;letter-spacing:.14em;margin-bottom:1px}
.pbn-card__name{font-size:.82rem;font-weight:600;color:var(--ink);display:block;max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}


/* ─── Mobile Sticky CTA ─── */
.m-sticky{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:900;
  background:rgba(255,255,255,.92);
  -webkit-backdrop-filter:blur(20px) saturate(1.5);backdrop-filter:blur(20px) saturate(1.5);
  border-top:1px solid var(--bd);padding:var(--sp-3);
  transform:translateY(100%);transition:transform .35s var(--ease-out);
}
.m-sticky.is-visible{transform:translateY(0)}
.m-sticky__inner{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2);max-width:500px;margin:0 auto}
.m-sticky__btn{
  display:flex;align-items:center;justify-content:center;gap:var(--sp-2);
  padding:var(--sp-3);border-radius:var(--r-sm);font-size:.8rem;font-weight:600;
  text-decoration:none;color:#fff;transition:all var(--dur) var(--ease);
}
.m-sticky__btn svg{width:17px;height:17px;flex-shrink:0}
.m-sticky__btn--wa{background:var(--wa)}.m-sticky__btn--wa:hover{box-shadow:0 4px 16px rgba(37,211,102,.35)}
.m-sticky__btn--tg{background:var(--tg)}.m-sticky__btn--tg:hover{box-shadow:0 4px 16px rgba(0,136,204,.35)}


/* ─── Lightbox ─── */
.lightbox{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s}
.lightbox.is-active{opacity:1;visibility:visible}
.lightbox__bg{position:absolute;inset:0;background:rgba(250,247,242,.94);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}
.lightbox__img{position:relative;z-index:1;max-width:92vw;max-height:88vh;object-fit:contain;border-radius:var(--r-md);box-shadow:var(--sh-xl);opacity:0;transform:scale(.95);transition:opacity .3s var(--ease),transform .3s var(--ease-out)}
.lightbox.is-active .lightbox__img{opacity:1;transform:scale(1)}
.lb-btn{position:absolute;z-index:2;width:44px;height:44px;display:grid;place-items:center;border-radius:var(--r-sm);background:var(--white);box-shadow:var(--sh-md);color:var(--ink);cursor:pointer;border:none;transition:all var(--dur) var(--ease)}
.lb-btn svg{width:18px;height:18px}
.lb-btn:hover{background:var(--terra);color:#fff}
.lb-close{top:var(--sp-5);right:var(--sp-5)}
.lb-prev{left:var(--sp-5);top:50%;transform:translateY(-50%)}
.lb-next{right:var(--sp-5);top:50%;transform:translateY(-50%)}
.lightbox__count{position:absolute;bottom:var(--sp-6);left:50%;transform:translateX(-50%);z-index:2;padding:5px 16px;background:var(--white);box-shadow:var(--sh-sm);border-radius:var(--r-xs);font-size:.7rem;font-weight:700;color:var(--ink-40)}


/* ─── Profile Mobile Responsive ─── */
@media(max-width:767px){
  .profile-page{padding-bottom:76px}
  .breadcrumbs{padding:var(--sp-3) 0 var(--sp-2);font-size:.65rem}
  .profile-nav{margin-bottom:var(--sp-3)}
  .pn-btn--back span{display:none}

  .profile-gallery{border-radius:var(--r-lg)}
  .pg-arrow{width:36px;height:36px;opacity:1}
  .pg-arrow svg{width:14px;height:14px}
  .pg-arrow--prev{left:var(--sp-2)}.pg-arrow--next{right:var(--sp-2)}
  .pg-play{width:50px;height:50px}.pg-play svg{width:20px;height:20px}
  .pg-thumbs-grid{grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:4px}

  .p-card{padding:var(--sp-4);margin-bottom:var(--sp-3);border-radius:var(--r-lg)}
  .p-card__title{font-size:.85rem;margin-bottom:var(--sp-3);padding-bottom:var(--sp-2)}
  .p-identity{flex-direction:column;gap:var(--sp-2);margin-bottom:var(--sp-4)}
  .p-identity__name{font-size:1.3rem}
  .p-identity__price{align-self:flex-start}.p-identity__price-num{font-size:1.2rem}
  .p-stats{margin-bottom:var(--sp-4)}.p-stat{padding:var(--sp-3) var(--sp-1)}.p-stat__val{font-size:1rem}
  .p-contact{padding:var(--sp-3);font-size:.78rem}

  .p-avail{grid-template-columns:repeat(7,1fr);gap:4px}
  .p-avail__day{padding:var(--sp-2) 2px}
  .p-avail__day-name{font-size:.48rem}
  .p-avail__day-status svg{width:13px;height:13px}

  .profile-bottom-nav{grid-template-columns:1fr;gap:var(--sp-3);padding-top:var(--sp-5);margin-top:var(--sp-5)}
  .pbn-card--next{justify-content:flex-start;text-align:left;flex-direction:row-reverse}
  .m-sticky{display:block}

  .lb-prev,.lb-next{width:38px;height:38px}
  .lb-prev{left:var(--sp-2)}.lb-next{right:var(--sp-2)}
  .lb-close{top:var(--sp-3);right:var(--sp-3);width:38px;height:38px}
}
@media(max-width:374px){
  .p-identity__name{font-size:1.1rem}.p-stat__val{font-size:.9rem}
  .p-contacts{grid-template-columns:1fr}
  .p-avail__day-name{font-size:.42rem;letter-spacing:0}
}

/* ─── Profile Animations ─── */
@keyframes pfUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.profile-col-gallery{animation:pfUp .4s var(--ease-out) both;animation-delay:.05s}
.profile-col-info .p-card:nth-child(1){animation:pfUp .4s var(--ease-out) both;animation-delay:.1s}
.profile-col-info .p-card:nth-child(2){animation:pfUp .4s var(--ease-out) both;animation-delay:.16s}
.profile-col-info .p-card:nth-child(3){animation:pfUp .4s var(--ease-out) both;animation-delay:.22s}
.profile-col-info .p-card:nth-child(4){animation:pfUp .4s var(--ease-out) both;animation-delay:.28s}
.profile-col-info .p-card:nth-child(5){animation:pfUp .4s var(--ease-out) both;animation-delay:.34s}
.profile-col-info .p-card:nth-child(6){animation:pfUp .4s var(--ease-out) both;animation-delay:.4s}
.profile-bottom-nav{animation:pfUp .4s var(--ease-out) both;animation-delay:.44s}
@media(prefers-reduced-motion:reduce){
  .profile-col-gallery,.profile-col-info .p-card,.profile-bottom-nav{animation:none!important}
  .p-hours__dot--on{animation:none!important}
}


/* ================================================================
   STATIC PAGES — About, FAQ, Contact, 404
   ================================================================ */
.static-page{max-width:900px;margin:0 auto;padding-bottom:var(--sp-16)}

/* ─── Hero ─── */
.sp-hero{text-align:center;padding:var(--sp-16) 0 var(--sp-12)}
.sp-hero__badge{
  display:inline-block;padding:6px 18px;
  background:var(--terra-wash);color:var(--terra);
  border-radius:var(--r-xs);font-size:.65rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.14em;margin-bottom:var(--sp-5);
}
.sp-hero__title{
  font-family:var(--ff-d);font-size:clamp(1.8rem,5vw,3rem);font-weight:400;
  font-variation-settings:'opsz' 72;line-height:1.15;color:var(--ink);
  margin-bottom:var(--sp-5);
}
.sp-hero__title em{font-style:italic;color:var(--terra)}
.sp-hero__desc{
  font-size:clamp(.88rem,1.5vw,1.05rem);color:var(--ink-40);
  line-height:1.7;max-width:600px;margin:0 auto;
}

/* ─── Sections ─── */
.sp-section{margin-bottom:var(--sp-14)}
.sp-section__title{
  font-family:var(--ff-d);font-size:clamp(1.2rem,3vw,1.7rem);font-weight:400;
  font-variation-settings:'opsz' 48;color:var(--ink);margin-bottom:var(--sp-6);
}
.sp-section__title--center{text-align:center}
.sp-section__subtitle{text-align:center;color:var(--ink-40);max-width:640px;margin:0 auto var(--sp-8);font-size:.88rem;line-height:1.7}
.sp-section p{color:var(--ink-70);line-height:1.75;margin-bottom:var(--sp-4)}
.sp-section p:last-child{margin-bottom:0}

/* Simple text block */
.sp-text-block{
  background:var(--white);border:1.5px solid var(--bd);border-radius:var(--r-xl);
  padding:var(--sp-8);
}
.sp-text-block p{color:var(--ink-70);line-height:1.8;margin-bottom:var(--sp-5);font-size:.9rem}
.sp-text-block p:last-child{margin-bottom:0}
.sp-section p a{color:var(--terra);text-decoration:underline;text-underline-offset:3px}

/* ─── Two Column ─── */
.sp-two-col{display:grid;grid-template-columns:1fr;gap:var(--sp-10);align-items:center}
@media(min-width:768px){.sp-two-col{grid-template-columns:1.3fr 1fr}}

.sp-deco-card{
  background:var(--terra);border-radius:var(--r-xl);padding:var(--sp-10) var(--sp-8);
  text-align:center;color:#fff;position:relative;overflow:hidden;
}
.sp-deco-card::before{
  content:'';position:absolute;top:-30px;right:-30px;width:100px;height:100px;
  border-radius:var(--r-full);background:rgba(255,255,255,.08);
}
.sp-deco-card__number{font-family:var(--ff-d);font-size:3.5rem;font-weight:300;line-height:1;font-variation-settings:'opsz' 144;margin-bottom:var(--sp-2)}
.sp-deco-card__label{font-size:.8rem;font-weight:600;opacity:.7;text-transform:uppercase;letter-spacing:.1em}

/* ─── Values Grid ─── */
.sp-values{display:grid;grid-template-columns:1fr;gap:var(--sp-5)}
@media(min-width:600px){.sp-values{grid-template-columns:1fr 1fr}}

.sp-value{
  background:var(--white);border:1.5px solid var(--bd);border-radius:var(--r-xl);
  padding:var(--sp-6);transition:all var(--dur) var(--ease);
}
.sp-value:hover{border-color:var(--terra-glow);box-shadow:var(--sh-md);transform:translateY(-3px)}
.sp-value__icon{
  width:44px;height:44px;display:grid;place-items:center;
  background:var(--terra-wash);border-radius:var(--r-sm);margin-bottom:var(--sp-4);
}
.sp-value__icon svg{width:22px;height:22px;color:var(--terra)}
.sp-value__title{font-family:var(--ff-d);font-size:1rem;font-weight:500;color:var(--ink);margin-bottom:var(--sp-2);font-variation-settings:'opsz' 48}
.sp-value__text{font-size:.82rem;color:var(--ink-40);line-height:1.65}

/* ─── Stats Row ─── */
.sp-stats-row{
  display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-4);
  background:var(--white);border:1.5px solid var(--bd);border-radius:var(--r-xl);
  padding:var(--sp-6);
}
@media(min-width:600px){.sp-stats-row{grid-template-columns:repeat(4,1fr)}}

.sp-stat-block{text-align:center;padding:var(--sp-3)}
.sp-stat-block__num{display:block;font-family:var(--ff-d);font-size:clamp(1.4rem,3vw,2rem);font-weight:400;color:var(--terra);font-variation-settings:'opsz' 72;line-height:1.2}
.sp-stat-block__label{font-size:.62rem;font-weight:700;color:var(--ink-20);text-transform:uppercase;letter-spacing:.12em;margin-top:var(--sp-1)}

/* ─── CTA Block ─── */
.sp-cta{
  text-align:center;background:var(--white);border:1.5px solid var(--bd);
  border-radius:var(--r-xl);padding:var(--sp-12) var(--sp-8);
}
.sp-cta__title{font-family:var(--ff-d);font-size:clamp(1.3rem,3vw,1.8rem);font-weight:400;color:var(--ink);margin-bottom:var(--sp-3);font-variation-settings:'opsz' 48}
.sp-cta__title em{font-style:italic;color:var(--terra)}
.sp-cta__desc{font-size:.88rem;color:var(--ink-40);margin-bottom:var(--sp-6);max-width:480px;margin-inline:auto}
.sp-cta__actions{display:flex;gap:var(--sp-3);justify-content:center;flex-wrap:wrap}

/* Buttons */
.sp-btn{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-3) var(--sp-6);border-radius:var(--r-sm);
  font-size:.82rem;font-weight:700;text-decoration:none;
  transition:all var(--dur) var(--ease);
}
.sp-btn--primary{background:var(--terra);color:#fff}
.sp-btn--primary:hover{background:var(--terra-dark);box-shadow:0 4px 16px rgba(198,125,91,.3);transform:translateY(-2px)}
.sp-btn--ghost{background:transparent;color:var(--ink-40);border:1.5px solid var(--bd)}
.sp-btn--ghost:hover{color:var(--terra);border-color:var(--terra-glow);background:var(--terra-wash)}


/* ================================================================
   FAQ
   ================================================================ */
.faq-group{margin-bottom:var(--sp-10)}
.faq-group:last-child{margin-bottom:0}
.faq-group__title{
  font-family:var(--ff-d);font-size:1.1rem;font-weight:500;color:var(--terra);
  font-variation-settings:'opsz' 48;margin-bottom:var(--sp-4);
  padding-bottom:var(--sp-3);border-bottom:1px solid var(--bd);
}
.faq-list{display:flex;flex-direction:column;gap:2px}

.faq-item{
  background:var(--white);border:1.5px solid var(--bd);border-radius:var(--r-sm);
  overflow:hidden;transition:border-color var(--dur) var(--ease);
}
.faq-item:hover{border-color:var(--bd-2)}
.faq-item.is-open{border-color:var(--terra-glow)}

.faq-item__q{
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);
  width:100%;padding:var(--sp-5) var(--sp-5);
  font-size:.88rem;font-weight:600;color:var(--ink);text-align:left;
  background:none;border:none;cursor:pointer;
}
.faq-item.is-open .faq-item__q{color:var(--terra)}

.faq-item__icon{
  width:20px;height:20px;flex-shrink:0;color:var(--ink-20);
  transition:transform .3s var(--ease),color .2s;
}
.faq-item.is-open .faq-item__icon{transform:rotate(180deg);color:var(--terra)}

.faq-item__a{
  max-height:0;overflow:hidden;
  transition:max-height .35s var(--ease);
}
.faq-item.is-open .faq-item__a{max-height:300px}

.faq-item__a-inner{padding:0 var(--sp-5) var(--sp-5)}
.faq-item__a-inner p{font-size:.84rem;color:var(--ink-70);line-height:1.7;margin:0}
.faq-item__a-inner a{color:var(--terra);text-decoration:underline;text-underline-offset:3px}
.faq-item__a-inner strong{color:var(--ink);font-weight:600}


/* ================================================================
   CONTACT
   ================================================================ */
.contact-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-8)}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr}}

.contact-cards{display:flex;flex-direction:column;gap:var(--sp-4)}
.contact-card{
  display:block;background:var(--white);border:1.5px solid var(--bd);border-radius:var(--r-xl);
  padding:var(--sp-6);text-decoration:none;
  transition:all var(--dur) var(--ease);
}
.contact-card:hover{border-color:var(--terra-glow);box-shadow:var(--sh-md);transform:translateY(-3px)}
.contact-card__icon{width:44px;height:44px;display:grid;place-items:center;border-radius:var(--r-sm);margin-bottom:var(--sp-4)}
.contact-card__icon svg{width:22px;height:22px}

.contact-card--wa .contact-card__icon{background:rgba(37,211,102,.08);color:var(--wa)}
.contact-card--tg .contact-card__icon{background:rgba(0,136,204,.08);color:var(--tg)}
.contact-card--email .contact-card__icon{background:var(--terra-wash);color:var(--terra)}

.contact-card__title{font-family:var(--ff-d);font-size:1.05rem;font-weight:500;color:var(--ink);margin-bottom:var(--sp-1);font-variation-settings:'opsz' 48}
.contact-card__desc{font-size:.78rem;color:var(--ink-40);margin-bottom:var(--sp-3)}
.contact-card__action{font-size:.78rem;font-weight:700;color:var(--terra)}

.contact-info{display:flex;flex-direction:column;gap:var(--sp-4)}
.contact-info__card{
  background:var(--cream);border:1.5px solid var(--bd);border-radius:var(--r-xl);padding:var(--sp-6);
}
.contact-info__title{
  display:flex;align-items:center;gap:var(--sp-2);
  font-family:var(--ff-d);font-size:.95rem;font-weight:500;color:var(--ink);
  font-variation-settings:'opsz' 48;margin-bottom:var(--sp-4);
  padding-bottom:var(--sp-3);border-bottom:1px solid var(--bd);
}
.contact-info__title svg{width:18px;height:18px;color:var(--terra)}
.contact-info__row{
  display:flex;justify-content:space-between;align-items:center;
  padding:var(--sp-2) 0;
}
.contact-info__row span{font-size:.8rem;color:var(--ink-40)}
.contact-info__row strong{font-size:.82rem;font-weight:700;color:var(--ink)}
.contact-info__text{font-size:.88rem;font-weight:600;color:var(--ink);margin-bottom:var(--sp-1)}
.contact-info__sub{font-size:.76rem;color:var(--ink-40);line-height:1.6}


/* ================================================================
   404 PAGE
   ================================================================ */
.page-404{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;min-height:60vh;padding:var(--sp-16) var(--sp-5);
}

.e404__visual{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-8)}
.e404__num{
  font-family:var(--ff-d);font-size:clamp(4rem,12vw,8rem);font-weight:300;
  font-variation-settings:'opsz' 144;color:var(--ink);line-height:1;opacity:.15;
}
.e404__circle{
  width:clamp(60px,12vw,100px);height:clamp(60px,12vw,100px);
  display:grid;place-items:center;
  background:var(--terra-wash);border:2px solid var(--terra-glow);
  border-radius:var(--r-full);
}
.e404__circle svg{width:50%;height:50%;color:var(--terra)}

.e404__title{
  font-family:var(--ff-d);font-size:clamp(1.3rem,3vw,1.8rem);font-weight:400;
  font-variation-settings:'opsz' 48;color:var(--ink);margin-bottom:var(--sp-3);
}
.e404__desc{font-size:.88rem;color:var(--ink-40);max-width:420px;margin-bottom:var(--sp-8);line-height:1.7}
.e404__actions{display:flex;gap:var(--sp-3);flex-wrap:wrap;justify-content:center}


/* ─── Static Pages Responsive ─── */
@media(max-width:767px){
  .sp-hero{padding:var(--sp-10) 0 var(--sp-8)}
  .sp-hero__badge{padding:5px 14px;font-size:.6rem}
  .sp-section{margin-bottom:var(--sp-10)}
  .sp-value{padding:var(--sp-5)}
  .sp-cta{padding:var(--sp-8) var(--sp-5)}
  .contact-card{padding:var(--sp-5)}
  .contact-info__card{padding:var(--sp-5)}
  .faq-item__q{padding:var(--sp-4)}
  .faq-item__a-inner{padding:0 var(--sp-4) var(--sp-4)}
}

/* Static pages animations */
@keyframes spFadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.sp-hero{animation:spFadeUp .5s var(--ease-out) both;animation-delay:.05s}
.sp-section:nth-child(2){animation:spFadeUp .5s var(--ease-out) both;animation-delay:.12s}
.sp-section:nth-child(3){animation:spFadeUp .5s var(--ease-out) both;animation-delay:.18s}
.sp-section:nth-child(4){animation:spFadeUp .5s var(--ease-out) both;animation-delay:.24s}
.sp-cta{animation:spFadeUp .5s var(--ease-out) both;animation-delay:.3s}
.page-404{animation:spFadeUp .5s var(--ease-out) both;animation-delay:.05s}
@media(prefers-reduced-motion:reduce){
  .sp-hero,.sp-section,.sp-cta,.page-404{animation:none!important}
}