/* DUFIE — public microsite. Onyx & Bone + Gold. Fold-line signature. */
:root{
  --onyx:#15130F; --ink:#1E1A14; --bone:#F2EDE3; --cream:#F8F3EA;
  --gold:#C2A04A; --goldd:#9A7B30; --muted:#7A6F5E; --line:#E6DDCD;
  --onyx-line:#2c2820; --onyx-muted:#9b917f;
  --maxw:1140px;
  --serif:"Fraunces",Georgia,serif; --sans:"Archivo",system-ui,sans-serif; --mono:"JetBrains Mono",monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.55}
img{max-width:100%;display:block}
a{color:inherit}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---- shared type ---- */
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted)}
.eyebrow.gold{color:var(--goldd)}
.eyebrow.gold-dim{color:var(--gold)}
.soon{color:var(--gold)}
.h2{font-family:var(--serif);font-weight:900;font-size:clamp(2rem,4.6vw,3.4rem);line-height:1.02;
  letter-spacing:-.01em;margin:.5rem 0 1rem;max-width:18ch}
.h3{font-family:var(--serif);font-weight:900;font-size:clamp(1.5rem,3vw,2.2rem);line-height:1.05;margin:.4rem 0 .8rem}
.lede{font-size:clamp(1rem,1.4vw,1.18rem);max-width:54ch;color:#4a4337}
.lede em{font-style:italic;color:var(--goldd)}
.light{color:var(--bone)}
.lede.light{color:#d8cfbf}

/* ---- buttons ---- */
.btn{display:inline-block;font-family:var(--mono);font-size:13px;letter-spacing:.08em;
  text-decoration:none;padding:14px 26px;border-radius:2px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease,background .18s,color .18s,border-color .18s}
.btn.solid{background:var(--gold);color:var(--onyx);font-weight:600}
.btn.solid:hover{background:#d4b25c;transform:translateY(-2px)}
.btn.ghost{border-color:var(--onyx-line);color:var(--bone)}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ============================ HERO ============================ */
.hero{position:relative;background:#FAF8F3;color:var(--ink);
  min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:90px 28px 70px;overflow:hidden}
.hero::before{/* faint radial warmth */content:"";position:absolute;inset:0;
  background:radial-gradient(120% 80% at 50% 28%,rgba(194,160,74,.13),transparent 62%);pointer-events:none}
.hero-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}
.hero .eyebrow{color:var(--goldd)}
.hero .btn.ghost{border-color:var(--line);color:var(--ink)}
.hero .btn.ghost:hover{border-color:var(--gold);color:var(--goldd)}
/* the brand lockup — portrait seated on the DUFIE wordmark, like the pack-base seal */
.lockup{display:flex;flex-direction:column;align-items:center;margin:18px 0 4px}
.lk-portrait{width:clamp(98px,12vw,152px);height:auto;object-fit:contain;margin-bottom:-1.5%}
.lk-word{font-family:var(--serif);font-weight:900;font-size:clamp(3.4rem,12vw,8rem);line-height:.9;
  letter-spacing:.05em;color:var(--ink)}
.lk-rule{display:flex;align-items:center;gap:10px;margin-top:16px}
.lk-rule .ln{width:clamp(40px,6vw,72px);height:1px;background:var(--goldd)}
.lk-rule .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.lk-slogan{font-family:var(--mono);font-size:clamp(.72rem,1.6vw,.95rem);letter-spacing:.4em;
  text-transform:uppercase;color:var(--goldd);margin-top:14px}
.hero-sub{color:#5a5347;max-width:42ch;margin:20px auto 0;font-size:1.02rem}
.hero-cta{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap;justify-content:center}

/* fold-line signature: a gold hairline notched like a crease */
.foldrule{position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--goldd) 18%,var(--gold) 50%,var(--goldd) 82%,transparent);
  opacity:.5}

/* ============================ STORY ============================ */
.story{background:var(--bone);padding:clamp(70px,10vw,130px) 0;position:relative;overflow:hidden}
.story .lede{margin-top:.3rem;font-size:clamp(1.1rem,1.7vw,1.4rem);max-width:48ch;line-height:1.6}
/* engagement: a faint woven lattice + a large watermark portrait */
.story::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    repeating-linear-gradient(45deg, transparent 0 40px, rgba(154,123,48,.055) 40px 41px),
    repeating-linear-gradient(-45deg, transparent 0 40px, rgba(154,123,48,.055) 40px 41px);}
.story-wm{position:absolute;right:-72px;bottom:-56px;width:min(470px,46vw);opacity:.06;pointer-events:none;z-index:0}
.story .wrap{position:relative;z-index:1}

/* ========================== PACKAGING ========================= */
.packaging{background:var(--cream);padding:clamp(70px,9vw,120px) 0 clamp(40px,6vw,70px)}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:40px}
.tile{position:relative;background:var(--cream);text-align:center}
.tile img{width:100%;aspect-ratio:4/3;object-fit:contain;mix-blend-mode:multiply}
.tile figcaption{display:flex;justify-content:center;gap:10px;align-items:baseline;
  padding:2px 0 16px;border-top:1px solid transparent}
.tile-nm{font-family:var(--serif);font-weight:600;font-size:1.05rem;color:var(--ink)}
.tile-vol{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;color:var(--goldd)}
.patterns-eyebrow{margin-top:clamp(44px,6vw,76px)}
.gallery.patterns{grid-template-columns:repeat(4,1fr);margin-top:22px}

/* ========================== 3D VIEWER ========================= */
.viewer-band{background:var(--onyx);color:var(--bone);padding:clamp(60px,8vw,100px) 0 clamp(60px,8vw,100px)}
.viewer-head .eyebrow{color:var(--gold)}
.viewer-head .h3{color:var(--bone)}
.viewer-frame{max-width:1280px;margin:34px auto 0;padding:0 16px}
.viewer{width:100%;height:min(74vh,680px);border:1px solid var(--onyx-line);border-radius:6px;
  display:block;background:var(--onyx)}

/* ============================= WHY ============================ */
.why{background:var(--onyx);color:var(--bone);padding:0 0 clamp(70px,9vw,110px)}
.why-grid{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  border-top:1px solid var(--onyx-line)}
.why-grid li{display:flex;flex-direction:column;gap:14px;padding:28px 22px 4px;
  font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;color:#cdc4b4;line-height:1.5}
.tick{width:13px;height:13px;flex:none;background:var(--gold);transform:rotate(45deg);
  border-radius:1px;opacity:.9}

/* ===================== CTA / WHOLESALE FORM =================== */
.cta-band{background:var(--bone);padding:clamp(70px,9vw,120px) 0}
.cta-split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(34px,5vw,80px);align-items:start}
.cta-copy{position:sticky;top:40px}
.form{display:flex;flex-direction:column;gap:14px;max-width:460px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea,.inline-row input{font-family:var(--sans);font-size:1rem;color:var(--ink);
  background:var(--cream);border:1px solid var(--line);border-radius:3px;padding:13px 14px;width:100%;
  transition:border-color .15s,box-shadow .15s}
.field textarea{resize:vertical}
.field input:focus,.field textarea:focus,.inline-row input:focus{outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(194,160,74,.22)}
.form .btn.solid{align-self:flex-start;margin-top:6px}
.form-error{font-family:var(--mono);font-size:12px;color:#9a3412;background:#fbeae2;
  border:1px solid #e9c4b4;border-radius:3px;padding:10px 12px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ============================ APPAREL ========================= */
.apparel{background:var(--onyx);color:var(--bone);text-align:center;
  padding:clamp(80px,11vw,150px) 0;position:relative;overflow:hidden}
.apparel::before{content:"";position:absolute;inset:0;
  background:radial-gradient(90% 70% at 50% 120%,rgba(194,160,74,.12),transparent 60%);pointer-events:none}
.apparel-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}
.apparel .h2.light{margin-top:.4rem}
.apparel .lede{margin:0 auto}
.apparel .form.inline{margin-top:30px;max-width:none;width:auto}
.inline-row{display:flex;gap:10px}
.inline-row input{min-width:min(280px,70vw);background:#1f1c16;border-color:var(--onyx-line);color:var(--bone)}
.inline-row input::placeholder{color:#7a7264}

/* ============================ DIVOLT ========================== */
.divolt{position:relative;overflow:hidden;background:var(--onyx);color:var(--bone);border-top:1px solid var(--onyx-line);
  padding:clamp(50px,7vw,90px) 0}
.divolt-wm{position:absolute;left:-46px;top:50%;transform:translateY(-50%);width:min(360px,38vw);
  opacity:.07;pointer-events:none;z-index:0}
.divolt .wrap{position:relative;z-index:1}
.divolt .eyebrow{color:var(--gold)}
.divolt-line{font-family:var(--serif);font-weight:400;font-size:clamp(1.15rem,2.2vw,1.7rem);
  line-height:1.4;max-width:30ch;margin-top:14px;color:#e6ddcd}
.divolt-line strong{color:var(--gold);font-weight:600}

/* ============================ FOOTER ========================== */
.foot{position:relative;background:linear-gradient(180deg,#15130F 0%,#3c2c1c 100%);color:#c2b6a1;
  padding:42px 0 52px;border-top:1px solid var(--onyx-line)}
.foot-portrait{display:block;width:64px;height:64px;object-fit:contain;margin:0 auto 16px}
.foot-inner{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.foot-mark{font-family:var(--serif);font-weight:900;font-size:1.6rem;letter-spacing:.14em;color:var(--bone)}
.foot-meta{display:flex;gap:22px;align-items:center;font-family:var(--mono);font-size:12px;letter-spacing:.06em}
.foot-meta a{color:var(--gold);text-decoration:none}
.foot-meta a:hover{text-decoration:underline}

/* ============================ MOTION ========================= */
.reveal{animation:rise .9s cubic-bezier(.2,.7,.2,1) both}
.reveal>*{animation:rise .8s cubic-bezier(.2,.7,.2,1) both}
.reveal>*:nth-child(1){animation-delay:.05s}
.reveal>*:nth-child(2){animation-delay:.14s}
.reveal>*:nth-child(3){animation-delay:.22s}
.reveal>*:nth-child(4){animation-delay:.30s}
.reveal>*:nth-child(5){animation-delay:.38s}
.reveal>*:nth-child(6){animation-delay:.46s}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ============================ RESPONSIVE ===================== */
@media(max-width:860px){
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gallery.patterns{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .cta-split{grid-template-columns:1fr}
  .cta-copy{position:static}
}
@media(max-width:520px){
  .gallery{grid-template-columns:repeat(2,1fr)}
  .inline-row{flex-direction:column}
  .foot-inner{flex-direction:column;align-items:flex-start}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal,.reveal>*{animation:none!important}
  .btn{transition:none}
}

/* ---- thank-you page ---- */
.thanks{min-height:100svh;background:var(--onyx);color:var(--bone);display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;gap:14px;padding:40px}
.thanks h1{font-family:var(--serif);font-weight:900;font-size:clamp(2.4rem,6vw,4rem)}
.thanks p{color:var(--onyx-muted);max-width:40ch}
.thanks a{color:var(--gold);font-family:var(--mono);font-size:13px;letter-spacing:.1em;text-decoration:none;margin-top:10px}
.thanks a:hover{text-decoration:underline}
