  :root{
    --paper:#F6EFE7;
    --paper-2:#EFE4D8;
    --blush:#E7CFC6;
    --ink:#2A1C25;
    --ink-soft:#5A4650;
    --plum:#4B2E42;
    --plum-700:#3B2334;
    --rose:#B87A72;
    --amber:#C0763A;
    --amber-soft:#E4B98A;
    --line:rgba(42,28,37,.14);
    --shadow:0 24px 60px -30px rgba(42,28,37,.45);
    --shadow-sm:0 12px 30px -18px rgba(42,28,37,.4);
    --r-lg:34px;
    --r-md:22px;
    --r-sm:14px;
    --wrap:1180px;
    --pad:clamp(20px,5vw,64px);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  @media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
  body{
    font-family:"Instrument Sans",system-ui,sans-serif;
    background:
      radial-gradient(60vw 55vw at 90% -6%, rgba(192,118,58,.11), transparent 60%),
      radial-gradient(52vw 52vw at -12% 20%, rgba(184,122,114,.12), transparent 55%),
      radial-gradient(60vw 60vw at 108% 78%, rgba(231,207,198,.34), transparent 58%),
      var(--paper);
    background-attachment:fixed;
    color:var(--ink);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  /* warm paper grain overlay */
  body::before{
    content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.5;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");
    mix-blend-mode:multiply;
  }
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}
  ::selection{background:var(--amber-soft);color:var(--plum-700)}
  /* ambient drifting light */
  .ambient{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
  .ambient i{position:absolute;border-radius:50%;filter:blur(70px);opacity:.55}
  .ambient i:first-child{width:46vw;height:46vw;background:radial-gradient(circle,rgba(192,118,58,.13),transparent 70%);top:-10vw;right:-8vw;animation:drift1 60s ease-in-out infinite alternate}
  .ambient i:last-child{width:42vw;height:42vw;background:radial-gradient(circle,rgba(184,122,114,.12),transparent 70%);bottom:-12vw;left:-10vw;animation:drift2 75s ease-in-out infinite alternate}
  @keyframes drift1{to{transform:translate(-14vw,16vh)}}
  @keyframes drift2{to{transform:translate(12vw,-14vh)}}
  @media (prefers-reduced-motion:reduce){.ambient i{animation:none}}
  h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:500;line-height:1.05;letter-spacing:-.01em}
  em{font-style:italic}
  .wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}
  .eyebrow{
    font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
    color:var(--rose);display:inline-flex;align-items:center;gap:.6em;
  }
  .eyebrow::before{content:"";width:26px;height:1px;background:var(--rose);opacity:.7}
  .serif{font-family:"Fraunces",serif}

  /* buttons */
  .btn{
    display:inline-flex;align-items:center;gap:.55em;font-weight:600;font-size:.95rem;
    padding:.95em 1.5em;border-radius:100px;cursor:pointer;border:1px solid transparent;
    transition:transform .2s ease,background .2s ease,box-shadow .2s ease,color .2s ease;
    line-height:1;white-space:nowrap;
  }
  .btn svg{width:17px;height:17px}
  .btn-primary{background:var(--plum);color:#F6EFE7;box-shadow:var(--shadow-sm)}
  .btn-primary:hover{background:var(--plum-700);transform:translateY(-2px)}
  .btn-amber{background:var(--amber);color:#fff}
  .btn-amber:hover{background:#a8632e;transform:translateY(-2px)}
  .btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
  .btn-ghost:hover{border-color:var(--plum);background:rgba(75,46,66,.04)}
  :focus-visible{outline:3px solid var(--amber);outline-offset:3px;border-radius:6px}

  /* ---------- NAV ---------- */
  header{position:sticky;top:0;z-index:50;transition:box-shadow .3s,background .3s}
  header.scrolled{background:rgba(246,239,231,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:16px}
  .brand{display:flex;align-items:center;gap:.7rem}
  .brand .mark{flex:none}
  .brand b{font-family:"Fraunces",serif;font-weight:600;font-size:1.18rem;letter-spacing:-.01em;display:block;line-height:1}
  .brand small{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
  .nav-links{display:flex;gap:1.7rem;align-items:center}
  .nav-links a{font-size:.92rem;font-weight:500;color:var(--ink-soft);position:relative;padding-block:4px}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--amber);transition:width .25s}
  .nav-links a:hover{color:var(--ink)}.nav-links a:hover::after{width:100%}
  .nav-cta{display:flex;align-items:center;gap:.8rem}
  .nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:10px;padding:9px;cursor:pointer}
  .nav-toggle svg{width:20px;height:20px;display:block}

  /* ---------- HERO ---------- */
  .hero{position:relative;padding-top:clamp(24px,4vw,46px);padding-bottom:clamp(30px,5vw,66px)}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,60px);align-items:center}
  .hero h1{font-size:clamp(2.3rem,5vw,3.9rem);letter-spacing:-.02em}
  .hero h1 em{color:var(--plum)}
  /* gentle load-in */
  @keyframes riseIn{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
  [data-rise]{opacity:0;animation:riseIn .75s cubic-bezier(.2,.7,.25,1) forwards;animation-delay:var(--d,0s)}
  @media (prefers-reduced-motion:reduce){[data-rise]{animation:none;opacity:1}}
  /* hand-drawn underline */
  .uw{position:relative;display:inline-block;color:var(--plum)}
  .uw svg{position:absolute;left:-2%;bottom:-.1em;width:104%;height:.24em;overflow:visible}
  .uw-path{stroke-dasharray:180;stroke-dashoffset:180;animation:drawuw 1s ease 1s forwards}
  @keyframes drawuw{to{stroke-dashoffset:0}}
  @media (prefers-reduced-motion:reduce){.uw-path{animation:none;stroke-dashoffset:0}}
  .hero p.lead{font-size:1.12rem;color:var(--ink-soft);max-width:42ch;margin-top:1.4rem}
  .hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
  .hero-meta{display:flex;flex-wrap:wrap;gap:1.6rem;margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid var(--line)}
  .hero-meta div{display:flex;flex-direction:column;gap:2px}
  .hero-meta b{font-family:"Fraunces",serif;font-size:1.5rem;font-weight:500;color:var(--plum)}
  .hero-meta span{font-size:.82rem;color:var(--ink-soft)}

  /* hero visual: two overlapping circles framing a photo */
  .hero-visual{position:relative;aspect-ratio:4/4.4}
  .hero-visual .photo{
    position:absolute;inset:0;border-radius:var(--r-lg) var(--r-lg) 120px var(--r-lg);
    overflow:hidden;box-shadow:var(--shadow);
  }
  .hero-visual .photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.82) contrast(1.02)}
  .hero-visual .photo::after{content:"";position:absolute;inset:0;
    background:linear-gradient(200deg,rgba(75,46,66,.28),rgba(192,118,58,.16) 55%,rgba(42,28,37,.42));
    mix-blend-mode:multiply}
  .hero-badge{
    position:absolute;left:-6%;bottom:8%;z-index:3;background:var(--paper);
    border-radius:var(--r-md);padding:16px 20px;box-shadow:var(--shadow);
    display:flex;align-items:center;gap:14px;max-width:260px;
  }
  .hero-badge .rings{flex:none}
  .hero-badge b{font-family:"Fraunces",serif;font-size:1.02rem;font-weight:600;display:block;line-height:1.15}
  .hero-badge span{font-size:.78rem;color:var(--ink-soft)}
  .hero-dot{position:absolute;top:-14px;right:8%;z-index:2;background:var(--blush);color:var(--plum-700);
    font-size:.76rem;font-weight:600;padding:9px 16px;border-radius:100px;box-shadow:var(--shadow-sm)}

  /* section rhythm */
  section{position:relative;z-index:2}
  .band{padding-block:clamp(34px,4.5vw,64px)}
  .sec-head{max-width:640px;margin-bottom:clamp(26px,3.5vw,44px)}
  .sec-head h2{font-size:clamp(1.9rem,3.8vw,3rem);margin-top:1rem}
  .sec-head p{color:var(--ink-soft);margin-top:1rem;font-size:1.05rem}

  /* ---------- PHILOSOPHY ---------- */
  .philo{background:var(--plum);color:#F2E4DC;border-radius:var(--r-lg);overflow:hidden}
  .philo-grid{display:grid;grid-template-columns:.85fr 1.15fr}
  .philo-photo{position:relative;min-height:420px}
  .philo-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.7)}
  .philo-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(59,35,52,.15),rgba(59,35,52,.6))}
  .philo-body{padding:clamp(32px,5vw,64px)}
  .philo-body .eyebrow{color:var(--amber-soft)}
  .philo-body .eyebrow::before{background:var(--amber-soft)}
  .philo-body h2{font-size:clamp(1.8rem,3.6vw,2.9rem);color:#fff;margin-top:1rem}
  .philo-body h2 em{color:var(--amber-soft)}
  .philo-body p{color:#E0CEC6;margin-top:1.3rem;font-size:1.06rem;max-width:46ch}
  .philo-list{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.8rem}
  .philo-list span{font-size:.82rem;padding:.5em 1em;border:1px solid rgba(228,185,138,.4);border-radius:100px;color:#F0DFD5}

  /* ---------- MIRROR (Oglindire — signature) ---------- */
  .mirror-grid{display:grid;grid-template-columns:1fr .94fr;gap:clamp(26px,4vw,60px);align-items:start}
  .mq{display:flex;align-items:baseline;gap:12px;width:100%;text-align:left;background:none;border:0;border-top:1px solid var(--line);
    padding:17px 4px;cursor:pointer;font-family:"Fraunces",serif;font-style:italic;
    font-size:clamp(1.02rem,1.7vw,1.28rem);color:var(--ink-soft);transition:color .25s,padding-left .3s}
  .mirror-list .mq:last-of-type{border-bottom:1px solid var(--line)}
  .mq::before{content:"„";color:var(--rose);font-size:1.4em;line-height:0;transition:color .25s}
  .mq:hover{color:var(--ink);padding-left:14px}
  .mq[aria-pressed="true"]{color:var(--plum);padding-left:14px}
  .mq[aria-pressed="true"]::before{color:var(--amber)}
  .mirror-panel{position:sticky;top:100px;background:linear-gradient(165deg,rgba(231,207,198,.55),rgba(216,167,156,.28));
    border:1px solid var(--line);border-radius:26px 26px 26px 96px;
    padding:clamp(28px,3.5vw,44px) clamp(26px,3.5vw,44px) clamp(34px,4vw,52px);min-height:330px}
  .mirror-panel .eyebrow{color:var(--amber)}
  .mirror-panel .eyebrow::before{background:var(--amber)}
  .mirror-msg{display:none}
  .mirror-msg.on{display:block;animation:msgIn .5s cubic-bezier(.2,.7,.25,1)}
  @keyframes msgIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
  @media (prefers-reduced-motion:reduce){.mirror-msg.on{animation:none}}
  .mirror-msg .say{font-family:"Fraunces",serif;font-size:clamp(1.25rem,2.1vw,1.65rem);line-height:1.35;color:var(--plum);margin-top:16px;letter-spacing:-.01em}
  .mirror-msg .more{margin-top:20px;display:inline-flex;align-items:center;gap:.4em;font-weight:600;color:var(--amber)}
  .mirror-msg .more:hover{color:#a8632e}
  .mirror-msg .note{display:block;margin-top:16px;color:var(--ink-soft);font-size:.88rem}

  /* ---------- METHOD (Imago 3 steps) ---------- */
  .method-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,36px);counter-reset:step}
  .step{padding:24px 8px 0;border-top:2px solid rgba(42,28,37,.16);transition:border-color .3s}
  .step:hover{border-top-color:var(--amber)}
  .step .num{counter-increment:step;font-family:"Fraunces",serif;font-size:.85rem;font-weight:600;color:var(--amber);letter-spacing:.05em}
  .step .num::before{content:"0" counter(step) " — "}
  .step h3{font-size:1.4rem;margin:.7rem 0 .6rem}
  .step p{color:var(--ink-soft);font-size:.96rem}
  .step .rings{margin-bottom:20px}

  /* ---------- SERVICES: three doors (arches) ---------- */
  .doors{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.2vw,26px);padding-top:18px}
  .door{background:var(--paper);border:1px solid var(--line);border-radius:170px 170px 26px 26px;
    padding:clamp(44px,4.5vw,60px) clamp(20px,2.2vw,30px) 26px;display:flex;flex-direction:column;
    transition:transform .3s,box-shadow .3s}
  .door:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
  .door .rings{margin:0 auto 14px;display:block}
  .door .who{display:block;text-align:center;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--rose)}
  .door h3{text-align:center;font-size:clamp(1.28rem,1.9vw,1.5rem);margin-top:.55rem}
  .door ul{list-style:none;margin-top:1.3rem;flex:1}
  .door li a{display:flex;align-items:center;gap:10px;padding:12px 2px;border-top:1px solid var(--line);
    font-size:.93rem;font-weight:500;color:var(--ink-soft);transition:color .2s,padding-left .25s}
  .door li a:hover{color:var(--ink);padding-left:8px}
  .door li a .nm{flex:1}
  .door li a small{font-size:.74rem;color:var(--rose);font-weight:600;white-space:nowrap}
  .door li a .arr{color:var(--amber);flex:none}
  .door .btn{justify-content:center;margin-top:1.2rem}
  .door.main{background:linear-gradient(172deg,var(--plum) 12%,var(--plum-700));border-color:transparent;box-shadow:var(--shadow);transform:translateY(-16px)}
  .door.main:hover{transform:translateY(-21px)}
  .door.main .who{color:var(--amber-soft)}
  .door.main h3{color:#fff}
  .door.main li a{color:#E0CEC6;border-top-color:rgba(242,228,220,.16)}
  .door.main li a:hover{color:#fff}
  .door.main li a small{color:var(--amber-soft)}

  /* ---------- WORKSHOPS (editorial columns) ---------- */
  .wk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,36px)}
  .wk{border-top:1px solid var(--line);padding-top:18px}
  .wk svg{width:22px;height:22px;color:var(--amber);margin-bottom:10px}
  .wk h3{font-size:1.18rem;margin-bottom:.4rem}
  .wk p{font-size:.92rem;color:var(--ink-soft)}

  /* ---------- FIRST SESSION: 3 gentle steps ---------- */
  .steps3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,44px)}
  .s3{border-top:1px solid var(--line);padding-top:18px}
  .s3 .n{font-family:"Fraunces",serif;font-style:italic;font-size:2.4rem;color:var(--amber);line-height:1;display:block}
  .s3 h3{font-size:1.2rem;margin:.5rem 0 .35rem}
  .s3 p{font-size:.93rem;color:var(--ink-soft)}

  /* ---------- KIDS BAND ---------- */
  .kids{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,56px);align-items:center;
    background:var(--blush);border-radius:var(--r-lg);padding:clamp(30px,4vw,56px)}
  .kids .eyebrow{color:var(--amber)}.kids .eyebrow::before{background:var(--amber)}
  .kids h2{font-size:clamp(1.7rem,3.4vw,2.6rem);margin-top:.9rem}
  .kids p{color:var(--ink-soft);margin-top:1rem;max-width:48ch}
  .kids .chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.5rem 0}
  .kids .chips span{font-size:.8rem;background:var(--paper);padding:.5em 1em;border-radius:100px;color:var(--plum)}
  .kids-visual{position:relative;aspect-ratio:1/1;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow);
    background:linear-gradient(165deg,#F6EDE3,#EAD3C9)}
  .kids-visual img{width:100%;height:100%;object-fit:cover;filter:saturate(.85)}
  .kids-illu{width:100%;height:100%;display:block}
  .kids-tag{position:absolute;left:16px;bottom:16px;z-index:2;background:rgba(246,239,231,.9);color:var(--plum-700);
    font-size:.72rem;font-weight:600;padding:7px 13px;border-radius:100px;box-shadow:var(--shadow-sm)}

  /* ---------- QUOTE (respiro) ---------- */
  .quote{position:relative;text-align:center;max-width:940px;margin-inline:auto;
    background:linear-gradient(160deg,rgba(231,207,198,.6),rgba(216,167,156,.32));
    border:1px solid var(--line);border-radius:var(--r-lg);
    padding:clamp(38px,5.5vw,60px) clamp(24px,5vw,72px)}
  .quote .rings{margin:0 auto 20px}
  .quote p{font-family:"Fraunces",serif;font-style:italic;font-weight:400;font-size:clamp(1.45rem,3.2vw,2.35rem);line-height:1.32;color:var(--plum);letter-spacing:-.01em}
  .quote cite{display:block;margin-top:20px;font-style:normal;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--rose);font-weight:600}

  /* ---------- PODCAST ---------- */
  .pod-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(22px,3vw,40px);align-items:start}
  .pod-thumb{position:relative;display:block;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);
    border:1px solid var(--line);aspect-ratio:16/9;background:#3B2334}
  .pod-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
  .pod-thumb:hover img,.pod-thumb:focus-visible img{transform:scale(1.05)}
  .pod-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(59,35,52,.55),transparent 60%)}
  .pod-thumb .play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:62px;height:62px;border-radius:50%;
    background:rgba(246,239,231,.94);display:grid;place-items:center;z-index:2;box-shadow:var(--shadow-sm);
    transition:transform .25s,background .25s}
  .pod-thumb .play svg{width:22px;height:22px;color:var(--plum);margin-left:3px}
  .pod-thumb:hover .play,.pod-thumb:focus-visible .play{transform:translate(-50%,-50%) scale(1.08);background:var(--amber)}
  .pod-thumb:hover .play svg,.pod-thumb:focus-visible .play svg{color:#fff}
  .pod-main h3{font-size:1.35rem;margin-top:1.15rem}
  .pod-main p{color:var(--ink-soft);font-size:.96rem;margin-top:.4rem}
  .pod-side{display:flex;flex-direction:column;gap:6px}
  .pod-item{display:flex;gap:14px;align-items:center;padding:9px;border-radius:16px;transition:background .2s}
  .pod-item:hover{background:rgba(75,46,66,.05)}
  .pod-item .pod-thumb{width:132px;flex:none;aspect-ratio:16/10;border-radius:13px}
  .pod-item .play{width:36px;height:36px}
  .pod-item .play svg{width:14px;height:14px}
  .pod-item-txt b{font-family:"Fraunces",serif;font-weight:500;font-size:1rem;line-height:1.2;color:var(--ink);display:block}
  .pod-item-txt small{color:var(--ink-soft);font-size:.82rem}
  .pod-all{display:inline-flex;align-items:center;gap:.4em;margin:12px 0 0 9px;font-weight:600;font-size:.9rem;color:var(--plum)}
  .pod-all:hover{color:var(--amber)}

  /* ---------- CONTACT ---------- */
  .contact{background:var(--plum);color:#F2E4DC;border-radius:var(--r-lg);overflow:hidden;
    display:grid;grid-template-columns:1.1fr .9fr}
  .contact-body{padding:clamp(32px,5vw,64px)}
  .contact-body .eyebrow{color:var(--amber-soft)}.contact-body .eyebrow::before{background:var(--amber-soft)}
  .contact-body h2{font-size:clamp(1.9rem,3.6vw,2.9rem);color:#fff;margin-top:1rem}
  .contact-body h2 em{color:var(--amber-soft)}
  .contact-body p{color:#E0CEC6;margin-top:1.1rem;max-width:44ch}
  .contact-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
  .btn-wa{background:#E4B98A;color:var(--plum-700)}
  .btn-wa:hover{background:#eec89e;transform:translateY(-2px)}
  .contact-note{margin-top:1.1rem;font-size:.88rem;color:#CDB8AE;display:flex;align-items:center;gap:.5em}
  .contact-note svg{width:15px;height:15px;flex:none;color:var(--amber-soft)}
  .contact-side{background:var(--plum-700);padding:clamp(28px,4vw,48px);display:flex;flex-direction:column;gap:1.4rem;justify-content:center}
  .contact-side .row{display:flex;gap:14px;align-items:flex-start}
  .contact-side .row svg{width:20px;height:20px;flex:none;margin-top:3px;color:var(--amber-soft)}
  .contact-side .row b{display:block;color:#fff;font-weight:600;font-size:.98rem}
  .contact-side .row span{color:#CDB8AE;font-size:.9rem}

  /* ---------- FOOTER ---------- */
  footer{padding-block:clamp(40px,6vw,72px) 32px}
  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2rem;padding-bottom:2.5rem;border-bottom:1px solid var(--line)}
  .foot-grid p{color:var(--ink-soft);font-size:.92rem;margin-top:1rem;max-width:34ch}
  .foot-col h4{font-family:"Instrument Sans";font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rose);margin-bottom:1rem}
  .foot-col a{display:block;color:var(--ink-soft);font-size:.94rem;padding-block:5px}
  .foot-col a:hover{color:var(--ink)}
  .foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:1.6rem;font-size:.84rem;color:var(--ink-soft)}

  /* reveal animation */
  .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
  .reveal.in{opacity:1;transform:none}
  @media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

  /* ---------- RESPONSIVE ---------- */
  @media(max-width:900px){
    .nav-links,.nav-cta .btn{display:none}
    .nav-toggle{display:block}
    .hero-grid,.philo-grid,.kids,.contact,.pod-grid,.mirror-grid{grid-template-columns:1fr}
    .philo-photo{min-height:280px}
    .method-steps,.wk-grid,.steps3{grid-template-columns:1fr}
    .doors{grid-template-columns:1fr;padding-top:0}
    .door{border-radius:130px 130px 26px 26px}
    .door.main{transform:none}
    .door.main:hover{transform:translateY(-5px)}
    .mirror-panel{position:static;min-height:0}
    .hero-visual{width:min(440px,100%);margin-inline:auto}
    .foot-grid{grid-template-columns:1fr 1fr}
    .contact-side{order:-1}
  }
  @media(max-width:560px){
    .foot-grid{grid-template-columns:1fr}
    .hero-meta{gap:1.1rem}
    .hero-badge{left:0}
  }
  /* mobile menu */
  .mobile-menu{display:none;position:fixed;inset:0;z-index:60;background:var(--paper);padding:24px;flex-direction:column}
  .mobile-menu.open{display:flex}
  .mobile-menu .mm-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}
  .mobile-menu a{font-family:"Fraunces",serif;font-size:1.8rem;padding-block:14px;border-bottom:1px solid var(--line)}
  .mobile-menu .btn{margin-top:2rem;justify-content:center}

/* ================================================== */
/* ============ INTERIOR PAGES (shared) ============= */
/* ================================================== */
.page-hero{padding-top:clamp(28px,5vw,60px);padding-bottom:clamp(10px,2vw,24px)}
.page-hero h1{font-size:clamp(2.1rem,4.6vw,3.5rem);letter-spacing:-.02em;max-width:20ch}
.page-hero .lead{font-size:1.1rem;color:var(--ink-soft);max-width:54ch;margin-top:1.2rem}
.page-hero .hero-cta{margin-top:1.8rem}
.crumbs{font-size:.85rem;color:var(--ink-soft);display:inline-flex;gap:.5em;margin-bottom:1.2rem}
.crumbs a{color:var(--rose);font-weight:600}
.crumbs a:hover{color:var(--amber)}
.nav-links a[aria-current="page"]{color:var(--ink)}
.nav-links a[aria-current="page"]::after{width:100%}

/* checklist ("pentru tine dacă...") */
.list-check{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 26px;margin-top:1.6rem}
.list-check li{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);font-size:.98rem;color:var(--ink-soft)}
.list-check li svg{width:18px;height:18px;flex:none;color:var(--amber);margin-top:3px}

/* FAQ accordion */
.faq{max-width:840px}
.faq details{border-top:1px solid var(--line)}
.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 4px;font-family:"Fraunces",serif;font-size:1.15rem;font-weight:500;color:var(--ink);transition:color .2s}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--plum)}
.faq summary .fx{flex:none;width:28px;height:28px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--amber);transition:transform .3s,background .2s}
.faq summary .fx svg{width:14px;height:14px}
.faq details[open] summary .fx{transform:rotate(45deg);background:var(--blush)}
.faq .fa{padding:0 4px 20px;color:var(--ink-soft);max-width:64ch}

/* generic two-column */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:center}
.grid2 .photo-frame{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.grid2 .photo-frame img{width:100%;height:100%;object-fit:cover;filter:saturate(.85)}

/* certificates / accreditations */
.cert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px)}
.cert{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);padding:22px;display:flex;gap:14px;align-items:flex-start}
.cert svg{width:26px;height:26px;flex:none;color:var(--amber);margin-top:2px}
.cert b{display:block;font-family:"Fraunces",serif;font-weight:500;font-size:1.05rem;line-height:1.25}
.cert span{font-size:.85rem;color:var(--ink-soft)}

/* map embed */
.map-frame{border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);aspect-ratio:16/9}
.map-frame iframe{width:100%;height:100%;border:0;display:block;filter:sepia(.18) saturate(.85)}

/* podcast page video grid */
.vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.6vw,30px)}
.vid .pod-thumb{aspect-ratio:16/9}
.vid b{display:block;font-family:"Fraunces",serif;font-weight:500;font-size:1.05rem;margin-top:.7rem;line-height:1.3}
.vid small{color:var(--ink-soft);font-size:.84rem}

/* compact CTA strip (interior pages) */
.cta-strip{background:linear-gradient(172deg,var(--plum),var(--plum-700));color:#F2E4DC;border-radius:var(--r-lg);
  padding:clamp(30px,4.5vw,56px);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.6rem}
.cta-strip h2{color:#fff;font-size:clamp(1.5rem,3vw,2.2rem);max-width:22ch}
.cta-strip h2 em{color:var(--amber-soft)}
.cta-strip p{color:#E0CEC6;margin-top:.5rem;font-size:.95rem;max-width:44ch}
.cta-strip .acts{display:flex;flex-wrap:wrap;gap:.8rem}

.steps3.steps4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.steps3.steps4{grid-template-columns:1fr}}

/* prose (legal / long text) */
.prose{max-width:760px;color:var(--ink-soft)}
.prose h2{font-size:1.5rem;color:var(--ink);margin:2rem 0 .7rem}
.prose p,.prose li{font-size:.98rem;margin-bottom:.8rem}
.prose ul{padding-left:1.2rem}

@media(max-width:900px){
  .list-check,.grid2,.cert-grid{grid-template-columns:1fr}
  .vid-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .vid-grid{grid-template-columns:1fr}
}

/* book product shot */
.book-shot{position:relative;max-width:430px;margin-inline:auto}
.book-shot img{width:100%;height:auto;border-radius:14px;box-shadow:var(--shadow);transform:rotate(-2.5deg);transition:transform .4s ease}
.book-shot:hover img{transform:rotate(-1deg) translateY(-4px)}
.book-shot .hero-dot{top:-12px;right:-4px}
.book-mini{max-width:300px;margin-inline:auto}
.book-mini img{width:100%;height:auto;border-radius:12px;box-shadow:var(--shadow);transform:rotate(-2deg)}
