/* MF Pulizie Varese — shared stylesheet (design handoff). Self-hosted Noto Sans + design tokens + components. */
/* ---- self-hosted Noto Sans (latin subset) ---- */
@font-face{font-family:'Noto Sans';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/noto-sans-400.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Noto Sans';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/noto-sans-500.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Noto Sans';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/noto-sans-600.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Noto Sans';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/noto-sans-700.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Noto Sans';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/fonts/noto-sans-800.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Noto Sans';font-style:normal;font-weight:900;font-display:swap;src:url('/assets/fonts/noto-sans-900.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}

:root{
    --yellow:#F4F12D;--purple:#9B3DF0;--maroon:#7a1b4d;--ink:#0c0c0c;--white:#fff;
    --lilac:#faf7ff;--r:26px;--r-md:16px;--r-sm:8px;
    --font:"Noto Sans","Helvetica Neue",Helvetica,Arial,sans-serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:var(--font);color:var(--ink);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  a{text-decoration:none;color:inherit}
  button{font-family:inherit;cursor:pointer;border:0;background:none}
  img{max-width:100%;display:block}
  .wrap{max-width:1180px;margin:0 auto;padding:0 26px;position:relative}
  h1,h2,h3{font-weight:800;line-height:1.04;letter-spacing:-.02em}

  /* pill */
  .pill{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;font-weight:700;font-size:13px;letter-spacing:.12em;text-transform:uppercase;padding:16px 30px;border-radius:999px;transition:transform .2s,background .2s}
  .pill:hover{transform:translateY(-2px);background:#000}
  .pill.ghost{background:#fff;color:var(--ink);border:2px solid var(--ink)}
  .pill.ghost:hover{background:#fff;transform:translateY(-2px)}
  .pill svg{width:16px;height:16px;fill:currentColor}

  /* ===== COMUNE PAGE (per-town template) ===== */
  .chero{background:var(--purple);color:#fff;overflow:hidden;position:relative}
  .chero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;padding:46px 26px 50px}
  .chero .eyebrow{color:#fff;opacity:.85;margin-bottom:8px}
  .chero h1{color:#fff;font-size:clamp(32px,5.2vw,54px);line-height:1.04;margin-bottom:16px}
  .chero p{font-size:18px;color:#fff;max-width:54ch;margin-bottom:24px}
  .chero .cta-row{display:flex;flex-wrap:wrap;gap:12px}
  .chero .pill.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
  .chero-photo{position:relative;display:grid;place-items:center;min-height:340px}
  .chero-photo .me{width:min(330px,86%);aspect-ratio:1/1;border-radius:50%;object-fit:cover;position:relative;z-index:2;box-shadow:0 24px 50px -20px rgba(0,0,0,.45)}
  .chero-photo .daisy{position:absolute;bottom:-4%;left:2%;width:min(120px,30%);z-index:3}
  .chero-photo .fern{position:absolute;top:-6%;right:-2%;width:min(120px,28%);z-index:1}
  @media(max-width:820px){.chero .wrap{grid-template-columns:1fr;text-align:center}.chero p{margin-inline:auto}.chero .cta-row{justify-content:center}.chero-photo{min-height:300px}}

  .cstats{background:var(--yellow)}
  .cstats .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:34px 26px}
  .cstat{text-align:center}
  .cstat .n{font-weight:800;font-size:clamp(34px,5vw,52px);letter-spacing:-.02em;line-height:1}
  .cstat .l{font-size:15px;color:#1a1a1a;margin-top:6px}
  @media(max-width:600px){.cstats .wrap{grid-template-columns:1fr;gap:18px}}

  .cserv{padding:56px 0}
  .cserv h2{font-size:clamp(24px,3.4vw,34px);margin-bottom:6px}
  .cserv .zsub{margin-bottom:26px}
  .cscards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .cscard{display:block;background:#fff;border:1px solid #eee;border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s}
  .cscard:hover{transform:translateY(-3px);box-shadow:0 16px 34px -20px rgba(0,0,0,.28)}
  .cscard img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
  .cscard .b{padding:14px 16px}
  .cscard .t{font-weight:800;font-size:16px;margin-bottom:3px}
  .cscard .d{font-size:13px;color:#666;line-height:1.4}
  @media(max-width:820px){.cscards{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:520px){.cscards{grid-template-columns:1fr}}

  /* ===== HEADER w/ menu ===== */
  header.site{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.06)}
  .site .nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:9px 0}
  .site .brand{display:flex;align-items:center}
  .site .brand img{height:78px;width:auto;display:block}
  .menu{display:flex;align-items:center;gap:24px;font-weight:600;font-size:15px}
  .navlink{padding:6px 2px;border-bottom:2px solid transparent;transition:border-color .2s;display:inline-flex;align-items:center;gap:6px;color:var(--ink)}
  .navlink:hover,.navlink.cur{border-color:var(--purple)}
  .caret{width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-top:-3px;opacity:.7;transition:transform .25s}
  .has-drop.open .caret{transform:rotate(-135deg);margin-top:2px}
  .has-drop{position:relative}
  .drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%);background:#fff;border-radius:18px;box-shadow:0 24px 60px -20px rgba(0,0,0,.30);padding:10px;width:340px;display:none;border:1px solid rgba(0,0,0,.05)}
  .has-drop.open .drop{display:block;animation:dropIn .2s ease}
  @keyframes dropIn{from{transform:translateX(-50%) translateY(-7px)}to{transform:translateX(-50%) translateY(0)}}
  .drop::before{content:"";position:absolute;top:-7px;left:50%;transform:translateX(-50%) rotate(45deg);width:14px;height:14px;background:#fff;border-left:1px solid rgba(0,0,0,.05);border-top:1px solid rgba(0,0,0,.05)}
  .drop a{display:flex;gap:13px;align-items:flex-start;padding:13px 14px;border-radius:12px;transition:background .15s}
  .drop a:hover{background:var(--lilac)}
  .drop .dtxt{display:flex;flex-direction:column;gap:5px}
  .drop .dt{display:block;font-weight:700;font-size:15px;color:var(--ink);line-height:1.1}
  .drop .dd{display:block;font-weight:400;font-size:12.5px;color:#777;line-height:1.4;min-height:2.8em}
  .drop .di{width:30px;height:30px;flex:none;border-radius:8px;background:var(--purple);display:grid;place-items:center;margin-top:2px}
  .drop .di svg{width:17px;height:17px;fill:#fff}
  .menu .pill{padding:11px 22px;font-size:12px}
  .burger{display:none;flex-direction:column;gap:5px;padding:8px}
  .burger span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:.25s}

  @media(max-width:860px){
    .menu{position:fixed;inset:64px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:#fff;padding:8px 20px 22px;border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 24px 40px -24px rgba(0,0,0,.3);transform:translateY(-130%);transition:transform .3s;font-size:17px}
    .menu.open{transform:translateY(0)}
    .navlink{padding:14px 2px;border-bottom:1px solid #f0f0f0}
    .has-drop{position:static}
    .drop{position:static;transform:none;width:auto;box-shadow:none;opacity:1;visibility:visible;padding:0 0 8px;border:0;display:none}
    .has-drop.open .drop{display:block;animation:none}
    .drop::before{display:none}
    .menu .pill{margin-top:14px;justify-content:center}
    .burger{display:flex}
    .site .brand img{height:56px}
  }

  /* ===== HERO ===== */
  .hero{position:relative;background:#fff;overflow:hidden}
  .hero .wrap{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding-top:54px;padding-bottom:54px}
  .hero h1.kw{font-size:clamp(19px,2.5vw,28px);font-weight:800;line-height:1.14;letter-spacing:-.005em;color:var(--purple);margin-bottom:14px}
  .hero .claim{font-size:clamp(38px,5.4vw,62px);font-weight:800;line-height:1.04;letter-spacing:-.025em;color:var(--ink)}
  .hero .sub{font-size:clamp(18px,2.2vw,24px);font-weight:400;color:#111;margin:16px 0 30px}
  .hero-right{position:relative;display:grid;place-items:center;min-height:480px}
  .hero .me{width:min(380px,84%);aspect-ratio:1/1;border-radius:50%;object-fit:cover;position:relative;z-index:2;box-shadow:0 22px 50px -22px rgba(0,0,0,.32)}
  .hero .flower{position:absolute;width:min(420px,100%);top:-20%;right:-20%;z-index:1}
  .hero .leaf{position:absolute;width:min(220px,52%);bottom:-6%;left:-2%;z-index:1;animation:floaty 6s ease-in-out infinite}
  @media(max-width:820px){.hero .wrap{grid-template-columns:1fr;gap:20px;padding-top:30px}.hero .claim{font-size:clamp(30px,8vw,44px)}.hero-right{min-height:330px}.hero .flower{top:-12%;right:-14%;width:min(300px,86%)}}

  .sec{padding:80px 0}
  .sec h2{font-size:clamp(30px,4.6vw,46px);font-weight:800}
  .sec h2 .hl{color:var(--purple)}
  .eyebrow{font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:13px;opacity:.7;margin-bottom:10px}

  /* ABOUT */
  .about{background:var(--purple);color:#fff;position:relative;overflow:hidden}
  .about .wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:40px;align-items:center;min-height:380px}
  .about .m-wrap{position:relative;justify-self:center}
  .about .bigM{display:block;width:min(320px,72vw);transform:rotate(-3deg);filter:drop-shadow(0 12px 28px rgba(0,0,0,.18));animation:sway 9s ease-in-out infinite}
  .about .daisy{position:absolute;width:60px;z-index:2}
  .about .d1{top:-6%;left:-12%}.about .d2{bottom:0;right:4%;width:72px}
  .about h2{color:#fff;font-size:clamp(28px,4vw,42px);margin-bottom:18px}
  .about p{font-size:18px;color:#fff;max-width:50ch}
  @media(max-width:820px){.about .wrap{grid-template-columns:1fr;text-align:center;min-height:0}.about .bigM{margin:0 auto}}

  /* SERVICES grid (yellow) */
  .svc{background:var(--yellow);overflow:hidden}
  .svc .head{margin-bottom:44px}
  .svc .head h2{font-size:clamp(34px,5.4vw,56px);line-height:1.02}
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
  .card{display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;cursor:pointer}
  .card .phwrap{position:relative}
  .card .fl{position:absolute;width:54px;height:54px;bottom:-6px;left:-6px;z-index:3;pointer-events:none}
  .card .ph{width:170px;height:170px;border-radius:50%;object-fit:cover;position:relative;z-index:1;transition:transform .25s}
  .card:hover .ph{transform:scale(1.04)}
  .card .lbl{background:var(--ink);color:#fff;font-weight:700;padding:12px 26px;border-radius:8px;margin:18px 0 14px;font-size:15px;min-width:260px;text-align:center}
  .card p{font-size:15.5px;color:#1a1a1a;max-width:34ch}
  @media(max-width:820px){.cards{grid-template-columns:1fr;gap:40px}}

  /* TESTIMONIALS */
  .testi{background:var(--purple);color:#fff}
  .testi .head{margin-bottom:44px}
  .testi h2{color:#fff}
  .quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
  .q{text-align:left}
  .q .avatar{position:relative;width:120px;margin-bottom:22px}
  .q .avatar .ph{width:120px;height:120px;border-radius:50%;object-fit:cover;position:relative;z-index:1}
  .q .avatar .fl{position:absolute;bottom:-12px;left:-16px;width:58px;z-index:2}
  .q p{font-size:15.5px;margin-bottom:12px;color:#fff}
  .q .who{font-weight:700;color:#fff}
  @media(max-width:820px){.quotes{grid-template-columns:1fr}}

  /* QUOTE CTA (yellow) */
  .quote{background:var(--yellow)}
  .quote .wrap{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
  .quote .logo{height:78px;width:auto;margin:0 0 20px;display:block}
  .quote h2{font-size:clamp(30px,4.4vw,48px);line-height:1.05}
  .quote p{font-size:19px;font-weight:500;margin:14px 0 26px}
  .btn-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}
  .btn-row .pill{justify-content:center;min-width:250px}
  .qico{width:46px;height:46px;flex:none}
  .qico svg{width:46px;height:46px;fill:#0c0c0c}
  .quote-right{position:relative;display:grid;place-items:center;min-height:420px}
  .quote .me{width:min(360px,86%);aspect-ratio:1/1;border-radius:50%;object-fit:cover;position:relative;z-index:2}
  .quote .fern{position:absolute;top:-2%;right:0;width:min(140px,32%);z-index:1}
  .quote .daisy{position:absolute;bottom:-2%;left:4%;width:min(140px,34%);z-index:3}
  @media(max-width:820px){.quote .wrap{grid-template-columns:1fr;text-align:center}.quote .logo{margin-inline:auto}.btn-row{justify-content:center}.quote-right{min-height:340px}}

  /* PACKAGES (white) */
  .pack{position:relative;overflow:hidden}
  .pack .head{margin-bottom:30px}
  .pack-cols{display:grid;grid-template-columns:1fr 1fr;gap:34px;max-width:760px}
  .pk h3{background:var(--ink);color:#fff;text-align:center;font-size:22px;font-weight:700;padding:15px 18px;border-radius:8px;margin-bottom:20px}
  .pk ul{list-style:none;display:grid;gap:11px}
  .pk li{display:flex;gap:10px;align-items:flex-start;font-size:16px}
  .pk li::before{content:"\2022";color:var(--ink);font-weight:900;font-size:18px;line-height:1.2;flex:none}
  .pack .cta-row{max-width:760px;text-align:center;margin-top:34px}
  .pack .branch{position:absolute;right:1%;top:26%;width:min(210px,19%);z-index:0;pointer-events:none}
  @media(max-width:760px){.pack-cols{grid-template-columns:1fr}.pack .branch{display:none}}

  /* BIG JOBS (purple) */
  .big{background:var(--purple);color:#fff}
  .big .wrap{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
  .big-photo{position:relative;display:grid;place-items:center;min-height:420px}
  .big-photo .me{width:min(410px,88%);aspect-ratio:1/1;border-radius:50%;object-fit:cover;position:relative;z-index:2;box-shadow:0 24px 50px -20px rgba(0,0,0,.45)}
  .big-photo .mbrush{position:absolute;top:-4%;left:2%;width:min(170px,40%);z-index:3}
  .big h2{color:#fff;margin-bottom:16px}
  .big p{font-size:18px;color:#fff;margin-bottom:26px}
  @media(max-width:820px){.big .wrap{grid-template-columns:1fr}.big-photo{min-height:330px;margin-bottom:8px}}

  /* DISTINGUISH (white) */
  .dist .head{margin-bottom:44px}
  .feats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
  .feat{text-align:left}
  .feat .ic{width:110px;height:110px;display:grid;place-items:center;margin:0 0 16px}
  .feat .ic img{width:94px;filter:brightness(0)}
  .feat h3{background:var(--ink);color:#fff;text-align:center;font-size:19px;font-weight:700;padding:13px;border-radius:8px;margin-bottom:12px}
  .feat p{color:#1a1a1a;font-size:15.5px}
  @media(max-width:760px){.feats{grid-template-columns:1fr;gap:38px}}

  /* FAQ (purple) */
  .faq{background:var(--purple);color:#fff}
  .faq .head{margin-bottom:42px}
  .faq h2{color:#fff}
  .faqs{display:grid;grid-template-columns:repeat(3,1fr);gap:38px}
  .fq .flower{width:50px;margin-bottom:16px;display:block;animation:spin 22s linear infinite;transform-origin:50% 50%}
  .fq h3{font-size:19px;color:#fff;margin-bottom:11px;font-weight:800}
  .fq p{font-size:15px;color:#fff}
  @media(max-width:820px){.faqs{grid-template-columns:1fr}}

  /* FOOTER */
  footer{background:var(--yellow);padding:56px 0 28px;position:relative}
  footer .wrap{position:relative}
  .fgrid{display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;align-items:center}
  .f-photo{position:relative;display:grid;place-items:center;min-height:430px}
  .f-photo .me{width:min(350px,80%);aspect-ratio:1/1;border-radius:50%;object-fit:cover;position:relative;z-index:2}
  .f-photo .daisy{position:absolute;top:-6%;right:-4%;left:auto;width:min(170px,40%);z-index:3}
  .f-photo .fern{position:absolute;bottom:-2%;left:-10%;width:min(160px,38%);z-index:3}
  .f-info h2{font-size:clamp(28px,4vw,44px);font-weight:800;margin-bottom:26px}
  .f-contacts{display:block}
  .fitem{margin-bottom:20px}
  .fitem .k{font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:14px;margin-bottom:4px}
  .fitem a{font-size:17px;font-weight:600;display:inline-flex;align-items:center;gap:8px}
  .fitem .wa{width:30px;height:30px;fill:#0c0c0c}
  .legal{text-align:center;font-size:clamp(9px,1vw,11.5px);color:#3a3a1a;max-width:none;margin:56px auto 0;line-height:1.6}
  @media(max-width:820px){footer .fgrid{grid-template-columns:1fr;text-align:center}.f-photo{min-height:340px;margin-bottom:24px}.legal{font-size:11px;max-width:60ch;margin-top:40px}}
  @media(max-width:640px){.fgrid{grid-template-columns:1fr;gap:18px}}

  /* ===== SERVICE / ZONE inner pages ===== */
  .crumb{font-size:13px;color:#666;padding-top:18px}
  .crumb a{color:var(--purple);font-weight:600}
  .crumb span{color:#aaa;margin:0 6px}
  .phero{padding:26px 0 8px}
  .phero .eyebrow{color:var(--purple);opacity:1}
  .phero h1{font-size:clamp(30px,5vw,50px);line-height:1.05;margin:6px 0 14px}
  .phero .lead{font-size:clamp(17px,2.2vw,21px);color:#222;max-width:62ch;margin-bottom:22px;line-height:1.5}
  .phero .cta-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
  .prose{padding:22px 0}
  .prose h2{font-size:clamp(24px,3.4vw,34px);margin:38px 0 14px}
  .prose h2:first-child{margin-top:0}
  .prose p{font-size:17px;color:#222;margin-bottom:14px;max-width:70ch}
  .prose ul{list-style:none;display:grid;gap:10px;margin:8px 0 22px;max-width:70ch}
  .prose ul li{display:flex;gap:10px;align-items:flex-start;font-size:16.5px;line-height:1.5}
  .prose ul li::before{content:"\2713";color:var(--purple);font-weight:900;flex:none}
  .callout{background:var(--yellow);border-radius:var(--r);padding:24px 28px;margin:26px 0;max-width:70ch}
  .callout h3{margin-bottom:8px;font-size:20px}
  .split{display:grid;grid-template-columns:.78fr 1.22fr;gap:44px;align-items:center;padding-block:26px}
  .split img{width:100%;max-width:340px;border-radius:var(--r);object-fit:cover;aspect-ratio:4/3;box-shadow:0 18px 40px -22px rgba(0,0,0,.3)}
  .split h2{font-size:clamp(22px,3vw,30px);margin-bottom:12px}
  .split p{font-size:16.5px;color:#222;margin-bottom:10px}
  @media(max-width:760px){.split{grid-template-columns:1fr;gap:18px}}
  .one-testi{background:var(--purple);color:#fff;padding:44px 0}
  .one-testi .wrap{display:flex;gap:30px;align-items:center;max-width:880px}
  .one-testi img{width:148px;height:148px;border-radius:50%;object-fit:cover;flex:none;box-shadow:0 18px 40px -20px rgba(0,0,0,.45)}
  .one-testi p{font-size:18px;margin-bottom:8px;color:#fff;line-height:1.5}
  .one-testi .who{font-weight:700}
  @media(max-width:600px){.one-testi .wrap{flex-direction:column;text-align:center}}
  .sfaq{padding:46px 0}
  .sfaq h2{font-size:clamp(24px,3.4vw,34px);margin-bottom:16px}
  .sfaq .item{border-bottom:1px solid #eee;padding:16px 0}
  .sfaq .qs{font-weight:700;font-size:17px;display:flex;justify-content:space-between;gap:12px;align-items:center;cursor:pointer}
  .sfaq .qs .mk{color:var(--purple);font-weight:900;font-size:24px;line-height:1;flex:none}
  .sfaq .ans{color:#333;font-size:16px;line-height:1.55;max-width:74ch;overflow:hidden;max-height:0;transition:max-height .3s,margin .3s}
  .sfaq .item.open .ans{max-height:240px;margin-top:10px}
  .related{background:var(--lilac);padding:56px 0}
  .related h2{font-size:clamp(24px,3.4vw,32px);margin-bottom:22px}
  .rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .rcard{display:block;background:#fff;border:1px solid #eee;border-radius:16px;padding:20px;transition:transform .2s,box-shadow .2s;cursor:pointer}
  .rcard:hover{transform:translateY(-3px);box-shadow:0 14px 30px -18px rgba(0,0,0,.3)}
  .rcard .t{font-weight:800;font-size:17px;margin-bottom:6px}
  .rcard .d{font-size:14.5px;color:#555;line-height:1.45}
  @media(max-width:760px){.rgrid{grid-template-columns:1fr}}
  .cta-band{background:var(--yellow);padding:52px 0;text-align:center}
  .cta-band h2{font-size:clamp(26px,4vw,38px);margin-bottom:10px}
  .cta-band p{font-size:18px;margin-bottom:22px}

  /* ZONE page */
  .zhero{background:var(--purple);color:#fff;padding:54px 0}
  .zhero h1{color:#fff;font-size:clamp(30px,5vw,50px);margin-bottom:12px}
  .zhero p{font-size:18px;color:#fff;max-width:62ch}
  .zsection{padding:50px 0}
  .zsection.alt{background:var(--lilac)}
  .ztitle{font-size:clamp(23px,3.2vw,32px);margin-bottom:6px}
  .zsub{font-size:16.5px;color:#555;margin-bottom:28px;max-width:64ch;line-height:1.5}
  .zcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(212px,1fr));gap:16px}
  .zcard{position:relative;display:flex;flex-direction:column;gap:7px;background:#fff;border:1px solid #ececec;border-radius:16px;padding:18px 20px;cursor:pointer;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s}
  .zcard:hover{transform:translateY(-3px);box-shadow:0 16px 34px -20px rgba(0,0,0,.28);border-color:#e6d9fb}
  .zcard .zn{font-weight:800;font-size:18.5px;letter-spacing:-.01em;position:relative;z-index:1}
  .zcard .zl{font-size:13px;color:#7a7a7a;display:inline-flex;align-items:center;gap:7px;position:relative;z-index:1}
  .zcard .zarrow{color:var(--purple);font-weight:900;transition:transform .2s}
  .zcard:hover .zarrow{transform:translateX(3px)}
  .zcard.feat{background:var(--purple);border-color:var(--purple)}
  .zcard.feat .zn{color:#fff}
  .zcard.feat .zl{color:rgba(255,255,255,.85)}
  .zcard.feat .zarrow{color:#fff}
  .zcard .zflower{position:absolute;right:-16px;bottom:-16px;width:66px;opacity:.10;pointer-events:none}
  .zcard:hover .zflower{opacity:.2}
  .zcard.feat .zflower{opacity:.22}
  .chips{display:flex;flex-wrap:wrap;gap:10px}
  .chip{background:#fff;border:1px solid #ece4fb;border-radius:999px;padding:9px 17px;font-weight:600;font-size:14px;color:#5a2b8c;transition:transform .15s,box-shadow .15s}
  .chip:hover{transform:translateY(-2px);box-shadow:0 8px 18px -12px rgba(123,40,200,.5)}
  @media(max-width:560px){.zcards{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}}

  /* FAB */
  .fab{position:fixed;right:22px;bottom:22px;z-index:99;width:60px;height:60px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 12px 28px -8px rgba(0,0,0,.45);transition:transform .2s}
  .fab:hover{transform:scale(1.08)}
  .fab .wa{width:32px;height:32px;fill:#fff}

  /* reveal — baseline VISIBLE; entrance plays when .in is added (never hides content) */
  .reveal{opacity:1;transform:none}
  .reveal.in{animation:revealUp .7s cubic-bezier(.2,.7,.2,1)}
  @keyframes revealUp{from{transform:translateY(22px)}to{transform:translateY(0)}}

  @keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
  @keyframes sway{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(3deg)}}
  @keyframes spin{to{transform:rotate(360deg)}}
  @media (prefers-reduced-motion: reduce){.hero .leaf,.about .bigM,.fq .flower{animation:none}.reveal.in{animation:none}}

/* decorative images: height follows width (avoid stretch from the height attr) */
.flower,.leaf,.bigM,.fl,.daisy,.fern,.mbrush,.branch,.zflower{height:auto}

/* package list items are links (internal linking / SEO) */
.pk li a{color:inherit;border-bottom:1px solid rgba(12,12,12,.22);transition:color .15s,border-color .15s}
.pk li a:hover{color:var(--purple);border-color:var(--purple)}
