:root{
    --ink:#2E1A2B;          /* blackberry */
    --ink-soft:#5A4350;
    --berry:#B4365F;        /* raspberry accent */
    --berry-deep:#7A2348;   /* mulberry */
    --paper:#FBF4E9;        /* warm cream */
    --paper-2:#F4E7D6;      /* deeper cream */
    --card:#FFFCF7;
    --sage:#6E7F58;         /* leaf */
    --sage-deep:#4F5C3F;
    --amber:#E59A3A;        /* marigold / oils */
    --blush:#F4DCD2;
    --line:rgba(46,26,43,.14);
    --line-strong:rgba(46,26,43,.28);
    --shadow:0 18px 50px -22px rgba(46,26,43,.45);
    --shadow-sm:0 8px 24px -14px rgba(46,26,43,.45);
    --r:18px;
    --maxw:1240px;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0;background:var(--paper);color:var(--ink);
    font-family:"Hanken Grotesk",system-ui,sans-serif;
    font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:600;line-height:1.02;margin:0;letter-spacing:-.01em}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
  .eyebrow{font-family:"Space Mono",monospace;text-transform:uppercase;letter-spacing:.22em;font-size:11.5px;color:var(--berry);font-weight:700}
  .mono{font-family:"Space Mono",monospace}
  .btn{
    display:inline-flex;align-items:center;gap:.55em;cursor:pointer;border:0;
    font-family:"Hanken Grotesk",sans-serif;font-weight:700;font-size:15px;
    padding:14px 26px;border-radius:100px;transition:transform .18s ease,box-shadow .18s ease,background .18s;
  }
  .btn:focus-visible{outline:3px solid var(--amber);outline-offset:3px}
  .btn-primary{background:var(--berry);color:#fff;box-shadow:var(--shadow-sm)}
  .btn-primary:hover{transform:translateY(-2px);background:var(--berry-deep)}
  .btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-strong)}
  .btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
  .btn-ink{background:var(--ink);color:var(--paper)}
  .btn-ink:hover{transform:translateY(-2px);background:#1c0f1a}

  /* ---------- announcement ---------- */
  .topbar{background:var(--ink);color:var(--paper);font-size:13px}
  .topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:42px;padding-top:6px;padding-bottom:6px}
  .ticker{display:flex;align-items:center;gap:26px;overflow:hidden;flex:1}
  .ticker span{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;opacity:.92}
  .ticker .dot{width:5px;height:5px;border-radius:50%;background:var(--amber)}
  .cur-toggle{display:flex;align-items:center;gap:0;background:rgba(251,244,233,.12);border:1px solid rgba(251,244,233,.25);border-radius:100px;padding:3px;flex-shrink:0}
  .cur-toggle button{background:transparent;border:0;color:var(--paper);font-family:"Space Mono",monospace;font-weight:700;font-size:12px;padding:5px 13px;border-radius:100px;cursor:pointer;opacity:.6;transition:.18s;letter-spacing:.04em}
  .cur-toggle button.on{background:var(--amber);color:var(--ink);opacity:1}
  .cur-toggle button:focus-visible{outline:2px solid var(--amber);outline-offset:2px}

  /* ---------- header ---------- */
  header.site{position:sticky;top:0;z-index:60;background:rgba(251,244,233,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  header.site .wrap{display:flex;align-items:center;gap:22px;min-height:74px}
  .brand{display:flex;align-items:center;gap:11px;font-family:"Fraunces",serif;font-weight:900;font-size:25px;letter-spacing:-.02em;color:var(--ink)}
  .brand .mark{flex-shrink:0}
  nav.main{display:flex;gap:4px;margin-left:8px}
  nav.main > a{position:relative;padding:9px 14px;border-radius:10px;font-weight:600;font-size:15px;transition:.16s;cursor:pointer}
  nav.main > a:hover{background:var(--paper-2);color:var(--berry-deep)}
  .util{margin-left:auto;display:flex;align-items:center;gap:6px}
  .icon-btn{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:transparent;border:0;cursor:pointer;color:var(--ink);transition:.16s;position:relative}
  .icon-btn:hover{background:var(--paper-2)}
  .icon-btn:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
  .cart-count{position:absolute;top:4px;right:4px;background:var(--berry);color:#fff;font-family:"Space Mono",monospace;font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 3px}
  .menu-toggle{display:none}

  /* ---------- hero ---------- */
  .hero{position:relative;padding:62px 0 38px;overflow:hidden}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
  .hero-eyebrow{display:inline-flex;align-items:center;gap:9px;margin-bottom:22px}
  .hero h1{font-size:clamp(46px,6.6vw,86px);font-weight:600}
  .hero h1 em{font-style:italic;color:var(--berry);font-weight:500}
  .hero p.lead{font-size:19px;color:var(--ink-soft);max-width:46ch;margin:24px 0 32px}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
  .hero-meta{display:flex;gap:30px;margin-top:38px;flex-wrap:wrap}
  .hero-meta .num{font-family:"Fraunces",serif;font-size:34px;font-weight:600;line-height:1}
  .hero-meta .lbl{font-family:"Space Mono",monospace;font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);margin-top:6px}

  /* signature: scent shelf */
  .shelf-wrap{position:relative}
  .shelf-card{background:linear-gradient(170deg,#fff 0%,var(--card) 100%);border:1px solid var(--line);border-radius:26px;padding:30px 26px 26px;box-shadow:var(--shadow);position:relative}
  .shelf-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}
  .shelf-head .ttl{font-family:"Fraunces",serif;font-weight:600;font-size:21px}
  .shelf-head .sub{font-family:"Space Mono",monospace;font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.12em;margin-top:3px}
  .shelf{display:flex;gap:14px;align-items:flex-end;justify-content:center;padding:12px 4px 18px;min-height:218px}
  .vial{position:relative;width:54px;cursor:pointer;text-align:center;transition:transform .3s cubic-bezier(.2,.8,.25,1)}
  .vial:hover,.vial:focus-visible{transform:translateY(-14px) rotate(-3deg);outline:none;z-index:3}
  .vial .neck{width:16px;height:16px;margin:0 auto;background:#d9c7a8;border-radius:3px 3px 0 0}
  .vial .cap{width:22px;height:11px;margin:0 auto -2px;background:var(--ink);border-radius:4px 4px 2px 2px}
  .vial .body{width:54px;height:118px;border-radius:9px 9px 16px 16px;position:relative;overflow:hidden;border:1.5px solid rgba(46,26,43,.18);box-shadow:inset -7px 0 12px -6px rgba(0,0,0,.25),inset 6px 0 10px -6px rgba(255,255,255,.6)}
  .vial .liquid{position:absolute;left:0;right:0;bottom:0;height:72%}
  .vial .label{position:absolute;left:50%;top:42%;transform:translateX(-50%);width:40px;height:34px;background:rgba(255,252,247,.92);border-radius:3px;display:grid;place-items:center}
  .vial .label b{font-family:"Space Mono",monospace;font-size:8px;color:var(--ink);letter-spacing:.02em}
  .vial .name{font-family:"Space Mono",monospace;font-size:10px;margin-top:9px;color:var(--ink-soft);letter-spacing:.02em}
  .scent-readout{background:var(--paper-2);border-radius:16px;padding:16px 18px;min-height:84px;display:flex;gap:16px;align-items:center;transition:.2s}
  .scent-readout .swatch{width:46px;height:46px;border-radius:12px;flex-shrink:0;box-shadow:inset 0 -8px 12px -8px rgba(0,0,0,.3)}
  .scent-readout .fam{font-family:"Space Mono",monospace;font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--berry);font-weight:700}
  .scent-readout .nm{font-family:"Fraunces",serif;font-size:20px;font-weight:600;margin:1px 0 2px}
  .scent-readout .notes{font-size:13.5px;color:var(--ink-soft)}
  .shelf-board{height:13px;background:linear-gradient(var(--paper-2),#e7d4ba);border-radius:5px;margin:-30px -6px 16px;box-shadow:0 9px 18px -10px rgba(46,26,43,.5)}
  .hint{font-family:"Space Mono",monospace;font-size:10.5px;color:var(--ink-soft);text-align:center;margin-top:14px;letter-spacing:.04em}

  /* floating berry doodles */
  .doodle{position:absolute;opacity:.5;pointer-events:none}

  /* ---------- trust strip ---------- */
  .trust{background:var(--ink);color:var(--paper);padding:18px 0}
  .trust .wrap{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
  .trust .item{display:flex;align-items:center;gap:11px;font-family:"Space Mono",monospace;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase}
  .trust .item svg{color:var(--amber);flex-shrink:0}

  /* ---------- sections ---------- */
  section{padding:84px 0}
  .sec-head{margin-bottom:42px;max-width:680px}
  .sec-head h2{font-size:clamp(32px,4.4vw,52px)}
  .sec-head p{color:var(--ink-soft);font-size:18px;margin:16px 0 0}
  .sec-head.center{margin-left:auto;margin-right:auto;text-align:center}

  /* craft cards */
  .crafts{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  .craft{position:relative;border-radius:var(--r);overflow:hidden;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;padding:26px;color:#fff;isolation:isolate;transition:transform .25s ease;border:1px solid var(--line)}
  .craft:hover{transform:translateY(-6px)}
  .craft .bg{position:absolute;inset:0;z-index:-2}
  .craft::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(transparent 28%,rgba(28,15,26,.86))}
  .craft .kicker{font-family:"Space Mono",monospace;font-size:11px;text-transform:uppercase;letter-spacing:.16em;opacity:.85}
  .craft h3{font-size:27px;margin:6px 0 4px;color:#fff}
  .craft .cnt{font-size:13.5px;opacity:.82}
  .craft .go{margin-top:14px;display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:14px}

  /* fragrance feature */
  .scent-feature{background:linear-gradient(160deg,var(--berry-deep),var(--berry) 70%);color:#fff;border-radius:30px;padding:54px;position:relative;overflow:hidden}
  .scent-feature .wrap2{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
  .scent-feature h2{color:#fff;font-size:clamp(30px,4vw,46px)}
  .scent-feature p{color:rgba(255,255,255,.86);font-size:18px;margin:18px 0 26px;max-width:42ch}
  .fam-chips{display:flex;flex-wrap:wrap;gap:10px}
  .fam-chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);color:#fff;padding:9px 16px;border-radius:100px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}
  .fam-chip .d{width:9px;height:9px;border-radius:50%}
  .scent-feature .price-pill{background:var(--amber);color:var(--ink);display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:100px;font-weight:700;font-family:"Space Mono",monospace;font-size:14px;margin-bottom:22px}

  /* product grid (shop by product) */
  .pgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
  .ptile{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px 18px;transition:.2s;display:flex;flex-direction:column;gap:10px;cursor:pointer}
  .ptile:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm);border-color:var(--line-strong)}
  .ptile .ic{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;background:var(--paper-2);color:var(--berry-deep)}
  .ptile h3{font-size:18px}
  .ptile .n{font-family:"Space Mono",monospace;font-size:11px;color:var(--ink-soft);letter-spacing:.04em}

  /* bestsellers */
  .rail{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  .pcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:.2s}
  .pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
  .pcard .thumb{height:178px;position:relative;display:grid;place-items:center}
  .pcard .badge{position:absolute;top:12px;left:12px;background:var(--ink);color:var(--paper);font-family:"Space Mono",monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em;padding:5px 10px;border-radius:100px}
  .pcard .wish{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;background:rgba(255,252,247,.9);display:grid;place-items:center;border:0;cursor:pointer;color:var(--ink)}
  .pcard .pbody{padding:16px 18px 20px;display:flex;flex-direction:column;flex:1}
  .pcard .cat{font-family:"Space Mono",monospace;font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--sage-deep)}
  .pcard h3{font-size:18px;margin:6px 0 8px;line-height:1.15}
  .pcard .stars{color:var(--amber);font-size:13px;letter-spacing:1px;margin-bottom:10px}
  .pcard .stars span{color:var(--ink-soft);font-family:"Space Mono",monospace;font-size:11px;letter-spacing:0;margin-left:5px}
  .pcard .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px}
  .pcard .price{font-family:"Space Mono",monospace;font-weight:700;font-size:18px}
  .pcard .price s{color:var(--ink-soft);font-weight:400;font-size:13px;margin-right:6px}
  .add{background:var(--ink);color:var(--paper);border:0;border-radius:100px;padding:9px 16px;font-weight:700;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:.16s}
  .add:hover{background:var(--berry)}
  .add:focus-visible{outline:2px solid var(--amber);outline-offset:2px}

  /* kits split */
  .kits{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border-radius:30px;overflow:hidden;border:1px solid var(--line)}
  .kits .left{background:var(--sage-deep);color:#fff;padding:54px}
  .kits .left h2{color:#fff}
  .kits .left p{color:rgba(255,255,255,.85);margin:18px 0 26px;font-size:18px}
  .kits-list{display:flex;flex-direction:column;gap:2px;background:var(--card)}
  .kits-list a{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:24px 30px;border-bottom:1px solid var(--line);transition:.16s;cursor:pointer}
  .kits-list a:last-child{border-bottom:0}
  .kits-list a:hover{background:var(--paper-2)}
  .kits-list .k-n{font-family:"Fraunces",serif;font-size:21px;font-weight:600}
  .kits-list .k-d{font-size:13.5px;color:var(--ink-soft);margin-top:2px}
  .kits-list .k-p{font-family:"Space Mono",monospace;font-weight:700;font-size:16px;flex-shrink:0;text-align:right}

  /* maker of the month */
  .maker{display:grid;grid-template-columns:.85fr 1.15fr;gap:46px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:30px;padding:14px 14px 14px 54px}
  .maker .photo{border-radius:22px;min-height:380px;position:relative;overflow:hidden;display:grid;place-items:center}
  .maker .mq{padding:38px 10px 38px 0}
  .maker blockquote{font-family:"Fraunces",serif;font-size:clamp(24px,2.7vw,33px);font-weight:500;line-height:1.18;margin:18px 0 22px}
  .maker .who{display:flex;align-items:center;gap:13px}
  .maker .who .av{width:46px;height:46px;border-radius:50%;background:var(--blush);display:grid;place-items:center;font-family:"Fraunces",serif;font-weight:600;color:var(--berry-deep);font-size:18px}
  .maker .who b{font-size:15px}
  .maker .who span{font-size:13px;color:var(--ink-soft)}

  /* learn */
  .learn{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .post{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:var(--card);transition:.2s;cursor:pointer}
  .post:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
  .post .ph{height:172px;position:relative;display:grid;place-items:center}
  .post .tag{position:absolute;top:12px;left:12px;background:rgba(255,252,247,.92);font-family:"Space Mono",monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em;padding:5px 11px;border-radius:100px}
  .post .pb{padding:20px}
  .post h3{font-size:21px;line-height:1.12}
  .post .meta{font-family:"Space Mono",monospace;font-size:11px;color:var(--ink-soft);margin-top:10px;letter-spacing:.04em}

  /* bulk band */
  .bulk{background:var(--ink);color:var(--paper);border-radius:30px;padding:52px;display:grid;grid-template-columns:1.2fr .8fr;gap:32px;align-items:center}
  .bulk h2{color:#fff;font-size:clamp(28px,3.6vw,42px)}
  .bulk p{color:rgba(251,244,233,.78);margin-top:14px;font-size:17px;max-width:46ch}
  .bulk .actions{display:flex;flex-direction:column;gap:12px}
  .bulk .stat{display:flex;gap:14px;align-items:baseline}
  .bulk .stat .b{font-family:"Fraunces",serif;font-size:40px;font-weight:600;color:var(--amber)}
  .bulk .stat .l{font-size:14px;color:rgba(251,244,233,.78)}

  /* reviews */
  .revs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
  .rev{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px}
  .rev .stars{color:var(--amber);font-size:14px;letter-spacing:2px;margin-bottom:12px}
  .rev p{font-size:16px;margin:0 0 16px}
  .rev .by{font-family:"Space Mono",monospace;font-size:12px;color:var(--ink-soft);letter-spacing:.04em}

  /* newsletter */
  .news{background:linear-gradient(150deg,var(--blush),var(--paper-2));border-radius:30px;padding:58px;text-align:center;position:relative;overflow:hidden}
  .news h2{font-size:clamp(30px,4vw,46px)}
  .news p{color:var(--ink-soft);font-size:18px;margin:14px auto 28px;max-width:46ch}
  .news form{display:flex;gap:10px;max-width:480px;margin:0 auto;flex-wrap:wrap;justify-content:center}
  .news input{flex:1;min-width:220px;padding:15px 20px;border-radius:100px;border:1.5px solid var(--line-strong);background:#fff;font-size:15px;font-family:inherit}
  .news input:focus-visible{outline:2px solid var(--berry);outline-offset:1px}
  .news small{display:block;margin-top:14px;font-family:"Space Mono",monospace;font-size:11px;color:var(--ink-soft);letter-spacing:.03em}

  /* footer */
  footer.site{background:var(--ink);color:var(--paper);padding:70px 0 30px;margin-top:10px}
  .fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:36px;padding-bottom:46px;border-bottom:1px solid rgba(251,244,233,.16)}
  footer.site h4{font-family:"Space Mono",monospace;font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--amber);margin:0 0 18px}
  footer.site ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px}
  footer.site ul a{font-size:14.5px;color:rgba(251,244,233,.8);transition:.15s}
  footer.site ul a:hover{color:#fff}
  .fbrand{display:flex;align-items:center;gap:11px;font-family:"Fraunces",serif;font-weight:900;font-size:25px;margin-bottom:16px}
  .fblurb{color:rgba(251,244,233,.7);font-size:14.5px;max-width:34ch}
  .socials{display:flex;gap:10px;margin-top:20px}
  .socials a{width:40px;height:40px;border-radius:11px;background:rgba(251,244,233,.1);display:grid;place-items:center;transition:.16s}
  .socials a:hover{background:var(--berry)}
  .fbot{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:26px;font-size:12.5px;color:rgba(251,244,233,.62)}
  .fbot .pay{display:flex;gap:8px;align-items:center;font-family:"Space Mono",monospace;letter-spacing:.04em}
  .fbot .pay span{border:1px solid rgba(251,244,233,.2);border-radius:6px;padding:3px 9px;font-size:11px}

  /* utility */
  .toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(140%);background:var(--ink);color:var(--paper);padding:14px 24px;border-radius:100px;font-weight:600;font-size:14px;box-shadow:var(--shadow);z-index:200;transition:transform .35s cubic-bezier(.2,.9,.3,1);display:flex;align-items:center;gap:10px}
  .toast.show{transform:translateX(-50%) translateY(0)}
  .toast .c{color:var(--amber)}

  /* ---------- responsive ---------- */
  @media (max-width:1080px){
    .pgrid{grid-template-columns:repeat(3,1fr)}
    .rail{grid-template-columns:repeat(2,1fr)}
    .crafts{grid-template-columns:repeat(2,1fr)}
  }
  @media (max-width:900px){
    nav.main{display:none}
    .menu-toggle{display:grid}
    .hero-grid{grid-template-columns:1fr;gap:40px}
    .scent-feature .wrap2{grid-template-columns:1fr;gap:30px}
    .kits{grid-template-columns:1fr}
    .maker{grid-template-columns:1fr;padding:14px}
    .maker .photo{order:-1}
    .maker .mq{padding:30px 24px 36px}
    .learn{grid-template-columns:1fr}
    .bulk{grid-template-columns:1fr}
    .revs{grid-template-columns:1fr}
    .fgrid{grid-template-columns:1fr 1fr;gap:30px}
  }
  @media (max-width:560px){
    body{font-size:16px}
    .wrap{padding:0 18px}
    section{padding:62px 0}
    .ticker span:nth-child(n+2){display:none}
    .pgrid,.rail,.crafts{grid-template-columns:1fr 1fr}
    .scent-feature,.news,.bulk,.kits .left{padding:34px 24px}
    .hero{padding:40px 0 20px}
    .hero-meta{gap:22px}
    .trust .wrap{justify-content:flex-start;gap:14px 26px}
    .fgrid{grid-template-columns:1fr}
    .maker .mq{padding:28px 22px 32px}
  }
  @media (prefers-reduced-motion:reduce){
    *{transition:none!important;scroll-behavior:auto}
  }