/* Dorset Custom Crafts — Site D
   Judge-driven synthesis: Site A's calm restraint & typography (both external judges' winner)
   + Site B's full-bleed hero & authentic photography + subtle handmade textures + inline contact.
   No marquee (Gemini flagged it as poor UX). Restraint over density. */

:root {
  --forest:#2f4233; --forest-deep:#1c281f; --sage:#7f9079;
  --cream:#f7f2e8; --cream-2:#efe7d6; --wood:#a9794a; --wood-deep:#8a5e36;
  --slate:#565d62; --ink:#2a2823; --ink-soft:#5c574c;
  --serif:"Fraunces",Georgia,serif; --sans:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;
  --maxw:1160px; --gutter:clamp(1.25rem,4vw,3rem); --section-y:clamp(4.5rem,9vw,8rem);
  --radius:5px; --shadow:0 20px 56px -24px rgba(28,40,31,.5); --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.68;font-size:1.0625rem}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.12;color:var(--forest-deep);letter-spacing:-.01em}
h1{font-size:clamp(2.5rem,6vw,4.6rem);font-weight:300}
h2{font-size:clamp(1.9rem,4vw,3.1rem)}
h3{font-size:clamp(1.2rem,2.2vw,1.55rem);color:var(--forest)}
p{max-width:62ch}
a{color:inherit}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y)}
.eyebrow{font-size:.76rem;letter-spacing:.24em;text-transform:uppercase;color:var(--wood-deep);font-weight:600;margin-bottom:1rem}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--ink-soft)}

/* subtle handmade paper / wood-grain texture on solid blocks (judge rec) */
.tex{position:relative}
.tex::before{content:"";position:absolute;inset:0;background-image:url("../img/wood-grain.jpg");background-size:cover;background-position:center;opacity:.05;mix-blend-mode:multiply;pointer-events:none}
.tex>*{position:relative;z-index:1}

/* nav */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:.85rem var(--gutter);background:rgba(247,242,232,.85);backdrop-filter:blur(10px);border-bottom:1px solid rgba(42,40,35,.08)}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none}
.brand img{height:34px;width:auto}
.brand b{font-family:var(--serif);font-weight:400;font-size:1.12rem;color:var(--forest-deep)}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{text-decoration:none;font-size:.95rem;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--forest)}
.nav-cta{padding:.55rem 1.1rem;border:1px solid var(--forest);border-radius:999px;color:var(--forest)!important}
.nav-cta:hover{background:var(--forest);color:var(--cream)!important}
.nav-toggle{display:none;background:none;border:0;font-size:1.5rem;color:var(--forest);cursor:pointer}

.btn{display:inline-block;text-decoration:none;cursor:pointer;font-size:.98rem;font-weight:500;padding:.85rem 1.7rem;border-radius:999px;border:1px solid transparent;transition:all .25s var(--ease)}
.btn-primary{background:var(--forest);color:var(--cream)}
.btn-primary:hover{background:var(--forest-deep);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(247,242,232,.4);color:var(--cream)}
.btn-ghost:hover{background:rgba(247,242,232,.12);border-color:var(--cream)}

/* hero — full bleed */
.hero{position:relative;min-height:94vh;display:flex;align-items:center;overflow:hidden;background:var(--forest-deep);color:var(--cream)}
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-media img{width:100%;height:122%;object-fit:cover;transform:translateY(0) scale(1.06);will-change:transform}
.hero::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(28,40,31,.55),rgba(28,40,31,.86)),radial-gradient(130% 100% at 75% 6%,rgba(60,83,67,.25),rgba(28,40,31,.55))}
.hero .wrap{position:relative;z-index:2}
.hero h1{color:var(--cream);max-width:16ch}
.hero .sub{font-size:clamp(1.1rem,2vw,1.4rem);color:rgba(247,242,232,.9);max-width:46ch;margin-top:1.6rem}
.hero .pills{margin-top:1.4rem;font-size:.95rem;letter-spacing:.04em;color:var(--sage)}
.hero-cta{margin-top:2.5rem;display:flex;gap:1rem;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:2;color:rgba(247,242,232,.6);font-size:1.5rem;animation:bob 2s infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,9px)}}

.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split.tight{grid-template-columns:.9fr 1.1fr}
.panel{background:var(--cream-2)}
.panel-forest{background:var(--forest);color:var(--cream)}
.panel-forest h2,.panel-forest h3{color:var(--cream)}
.panel-forest p{color:rgba(247,242,232,.85)}
.img-block{width:100%;display:block;border-radius:var(--radius);object-fit:cover;box-shadow:var(--shadow)}
.img-block.tall{aspect-ratio:3/4}

/* work grid (clean, no marquee) */
.grid-work{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.5rem}
.ph{position:relative;border-radius:var(--radius);overflow:hidden;background:linear-gradient(135deg,var(--cream-2),#e3d8c2);border:1px solid rgba(138,94,54,.25);display:flex;align-items:flex-end;aspect-ratio:4/3;min-height:200px;padding:1rem}
.ph::after{content:"▣";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.8rem;color:rgba(138,94,54,.22)}
.ph span{position:relative;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;color:var(--wood-deep)}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2.5rem}
.step .ph-img{height:190px;border-radius:var(--radius);overflow:hidden;margin-bottom:1rem}
.step .ph-img img{width:100%;height:100%;object-fit:cover}
.step .num{font-family:var(--serif);font-size:2rem;color:var(--wood);line-height:1}
.step h3{margin:.4rem 0 .4rem}

/* materials full-bleed */
.materials{position:relative;min-height:74vh;display:flex;align-items:center;overflow:hidden;color:var(--cream)}
.materials img.bg{position:absolute;inset:0;width:100%;height:120%;object-fit:cover;z-index:0;will-change:transform}
.materials::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(rgba(28,40,31,.82),rgba(28,40,31,.82))}
.materials .wrap{position:relative;z-index:2;text-align:center;max-width:56ch}
.materials h2,.materials .eyebrow{color:var(--cream)}
.materials h2{text-shadow:0 2px 24px rgba(0,0,0,.35)}

/* inline contact on dark bg (judge rec) */
.contact{background:var(--forest);color:var(--cream)}
.contact .grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.form{display:grid;gap:1rem}
.form input,.form textarea,.form select{width:100%;padding:.85rem 1rem;border:1px solid rgba(247,242,232,.25);border-radius:var(--radius);background:rgba(247,242,232,.06);color:var(--cream);font-family:var(--sans);font-size:1rem}
.form input::placeholder,.form textarea::placeholder{color:rgba(247,242,232,.5)}
.form textarea{min-height:120px;resize:vertical}
.form button{justify-self:start;background:var(--cream);color:var(--forest-deep)}
.form button:hover{background:#fff}

.footer{background:var(--forest-deep);color:rgba(247,242,232,.78);padding-block:3rem}
.footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;align-items:start}
.footer img{height:54px;margin-bottom:.75rem}
.footer h4{font-family:var(--serif);color:var(--cream);font-weight:400;font-size:1.2rem;margin-bottom:.6rem}
.footer a{color:rgba(247,242,232,.78);text-decoration:none;display:block;margin-bottom:.35rem;font-size:.95rem}
.footer a:hover{color:var(--sage)}
.footer .fine{margin-top:2.2rem;padding-top:1.4rem;border-top:1px solid rgba(247,242,232,.12);font-size:.82rem;color:rgba(247,242,232,.55);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

.draft-flag{background:var(--wood);color:#fff;text-align:center;font-size:.8rem;letter-spacing:.06em;padding:.5rem}

@media(max-width:860px){
  .split,.split.tight,.contact .grid{grid-template-columns:1fr}
  .grid-work{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr}
  .footer .cols{grid-template-columns:1fr}
  .nav-links{position:fixed;inset:60px 0 auto 0;background:var(--cream);flex-direction:column;padding:1.5rem var(--gutter);gap:1.25rem;border-bottom:1px solid rgba(42,40,35,.1);transform:translateY(-130%);transition:transform .3s var(--ease)}
  .nav-links.open{transform:none}
  .nav-toggle{display:block}
}
@media(max-width:520px){.grid-work{grid-template-columns:1fr}}
