/* ============================================================
   deska & co — storefront demo styles
   ============================================================ */
:root{
  --ink:#24281A;--olive:#5B6233;--olive-deep:#424A22;--brown:#4A3526;
  --gold:#C9B36A;--cream:#ECE4D3;--cream-2:#F5EFE2;--tan:#E2C9A3;
  --line:rgba(36,40,26,.16);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--ink);font-family:'Mulish',system-ui,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
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='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E")}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
h1,h2,h3,.display{font-family:'Fraunces',Georgia,serif;font-weight:400;line-height:1.05;letter-spacing:-.01em}
.eyebrow{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;font-weight:700;color:var(--olive)}
a{color:inherit;text-decoration:none}
img{display:block}

.btn{display:inline-flex;align-items:center;gap:.55em;font-weight:700;font-size:.85rem;letter-spacing:.04em;padding:.9em 1.7em;border-radius:2px;cursor:pointer;border:1px solid transparent;font-family:inherit;transition:transform .25s,background .25s,color .25s,border-color .25s}
.btn-solid{background:var(--olive);color:var(--cream-2)}
.btn-solid:hover{background:var(--olive-deep);transform:translateY(-2px)}
.btn-ghost{border-color:var(--ink);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--olive);color:var(--olive);transform:translateY(-2px)}
.btn-light{background:var(--cream-2);color:var(--ink)}
.btn-light:hover{background:#fff;transform:translateY(-2px)}

/* header */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(8px);background:rgba(236,228,211,.85);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.nav.scrolled{box-shadow:0 8px 24px -16px rgba(36,40,26,.5)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:78px;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.badge{width:46px;height:46px;flex:none}
.brand .wm{font-family:'Fraunces',serif;font-size:1.4rem;font-weight:500;letter-spacing:.02em;line-height:1}
.brand .wm small{display:block;font-family:'Mulish',sans-serif;font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;color:var(--olive);font-weight:700;margin-top:3px}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--olive);transition:width .3s}
.nav-links a:hover::after{width:100%}
.nav-cta{display:inline-flex}
.burger{display:none;background:none;border:0;cursor:pointer;color:var(--ink);padding:6px}

/* mobile slide-down menu */
.mobile-menu{position:fixed;inset:0 0 auto 0;top:78px;background:var(--cream-2);border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s ease;z-index:49;padding:18px 28px 26px}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{display:block;padding:13px 0;font-size:1rem;font-weight:600;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:18px;width:100%;justify-content:center}

/* hero */
.hero{padding:72px 0 84px}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center}
.hero .loc{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--olive);margin-bottom:18px}
.hero .loc::before{content:"";width:26px;height:1px;background:var(--olive)}
.hero h1{font-size:clamp(2.8rem,6vw,5rem);margin-bottom:.3em}
.hero h1 em{font-style:italic;color:var(--olive)}
.hero p.lede{font-size:1.1rem;max-width:46ch;color:#3a3d2c}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero-photo{position:relative;border-radius:5px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 30px 60px -30px rgba(36,40,26,.6)}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo .stamp{position:absolute;bottom:18px;left:18px;background:rgba(91,98,51,.92);color:var(--cream-2);font-family:'Fraunces',serif;font-style:italic;font-size:.95rem;padding:8px 16px;border-radius:2px}

section{position:relative;z-index:2}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:44px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(1.9rem,4vw,2.8rem)}
.sec-head .sub{color:#54573f;font-size:.98rem;margin-top:.4em;max-width:52ch}

/* offerings */
.make{padding:92px 0}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.card{background:var(--cream-2);border:1px solid var(--line);border-radius:4px;overflow:hidden;cursor:pointer;transition:transform .3s,box-shadow .3s}
.card:hover{transform:translateY(-6px);box-shadow:0 20px 44px -26px rgba(36,40,26,.55)}
.card .pic{aspect-ratio:1/1;overflow:hidden}
.card .pic img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .pic img{transform:scale(1.05)}
.card-body{padding:20px 20px 24px}
.card-body .name{font-family:'Fraunces',serif;font-size:1.3rem}
.card-body .desc{font-size:.85rem;color:#54573f;margin:.4em 0 1em}
.card-body .more{font-size:.74rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--olive);border-bottom:1.5px solid transparent;padding-bottom:2px;transition:border-color .25s}
.card:hover .card-body .more{border-color:var(--olive)}

/* classes */
.classes{background:var(--brown);color:var(--cream-2);padding:104px 0}
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split .eyebrow{color:var(--gold)}
.split h2{font-size:clamp(2rem,4.4vw,3rem);margin:.3em 0 .55em}
.split p{color:#e7ddcb;max-width:46ch;margin-bottom:1.1em}
.split ul{list-style:none;margin:0 0 26px}
.split li{padding:9px 0 9px 26px;position:relative;border-bottom:1px solid rgba(255,255,255,.12);font-size:.96rem}
.split li::before{content:"";position:absolute;left:0;top:17px;width:11px;height:11px;border:1.5px solid var(--gold);border-radius:50%}
.split-pics{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.split-pics img{width:100%;height:100%;object-fit:cover;border-radius:4px;cursor:zoom-in}
.split-pics .tall{grid-row:span 2;aspect-ratio:3/5}
.split-pics .short{aspect-ratio:1/1}

/* events */
.events{padding:96px 0}
.events-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:26px;margin-top:8px}
.ev{padding:30px 26px;border:1px solid var(--line);border-radius:4px;background:var(--cream-2)}
.ev h3{font-size:1.35rem;margin-bottom:.4em}
.ev p{font-size:.9rem;color:#54573f}

/* shipping */
.ship{background:var(--tan);padding:74px 0}
.ship-in{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.ship h2{font-size:clamp(1.7rem,3.6vw,2.4rem);color:var(--brown);max-width:20ch}
.ship p{color:#4a3a2c;max-width:40ch;margin-top:.5em}

/* order band */
.order{background:var(--olive);color:var(--cream-2);padding:90px 0;text-align:center}
.order h2{font-size:clamp(2rem,4.2vw,3rem);max-width:20ch;margin:0 auto .35em}
.order p{max-width:48ch;margin:0 auto 14px;opacity:.9}
.order .lead{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;opacity:.8;margin-bottom:26px}
.order-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* gallery */
.gallery{padding:90px 0}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gal-grid img{width:100%;height:100%;object-fit:cover;border-radius:3px;aspect-ratio:1/1;cursor:zoom-in;transition:transform .4s}
.gal-grid img:hover{transform:scale(1.04)}

/* footer */
footer{background:var(--ink);color:#cfc9b6;padding:66px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
footer .brand .wm{color:var(--cream-2)}
footer .tag{font-size:.9rem;color:#a8a892;margin-top:14px;max-width:32ch}
.fcol h4{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:15px;font-weight:700}
.fcol a,.fcol p{display:block;font-size:.88rem;margin-bottom:10px;color:#cfc9b6}
.fcol a:hover{color:var(--cream-2)}
.foot-base{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;font-size:.76rem;color:#8c8c78;flex-wrap:wrap;gap:10px}

/* reveal */
.rise{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s}
.rise.in{opacity:1;transform:none}

/* ===== modal (order / inquiry) ===== */
.modal-back{position:fixed;inset:0;background:rgba(36,40,26,.55);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .28s}
.modal-back.open{opacity:1;pointer-events:auto}
.modal{background:var(--cream-2);border-radius:6px;max-width:520px;width:100%;max-height:90vh;overflow:auto;padding:34px 32px 30px;transform:translateY(16px) scale(.98);transition:transform .28s;position:relative}
.modal-back.open .modal{transform:none}
.modal h3{font-size:1.7rem;margin-bottom:.2em}
.modal .msub{color:#54573f;font-size:.92rem;margin-bottom:20px}
.modal label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--olive);margin:14px 0 6px}
.modal input,.modal select,.modal textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:3px;background:#fff;font-family:inherit;font-size:.95rem;color:var(--ink)}
.modal textarea{min-height:84px;resize:vertical}
.modal .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.modal .actions{margin-top:24px;display:flex;gap:12px;justify-content:flex-end}
.modal .close{position:absolute;top:14px;right:14px;background:none;border:0;cursor:pointer;color:var(--ink);opacity:.6;padding:6px;line-height:0}
.modal .close:hover{opacity:1}
.modal .ok{text-align:center;padding:18px 0 6px}
.modal .ok .check{width:56px;height:56px;border-radius:50%;background:var(--olive);color:var(--cream-2);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.hidden{display:none}

/* ===== lightbox ===== */
.lightbox{position:fixed;inset:0;background:rgba(20,22,14,.92);z-index:110;display:flex;align-items:center;justify-content:center;padding:30px;opacity:0;pointer-events:none;transition:opacity .28s}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:4px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7)}
.lightbox .lb-close{position:absolute;top:22px;right:26px;background:none;border:0;color:#fff;cursor:pointer;opacity:.85;padding:8px}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:0;color:#fff;cursor:pointer;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox .lb-nav:hover{background:rgba(255,255,255,.25)}
.lightbox .lb-prev{left:22px}.lightbox .lb-next{right:22px}

@media(max-width:900px){
  .nav-links,.nav .nav-cta{display:none}
  .burger{display:block}
  .hero-grid,.split{grid-template-columns:1fr;gap:34px}
  .grid{grid-template-columns:repeat(2,1fr)}
  .events-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .modal .row{grid-template-columns:1fr}
  .lightbox .lb-nav{width:40px;height:40px}
}
@media(max-width:520px){.grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.rise{opacity:1;transform:none}html{scroll-behavior:auto}}
:focus-visible{outline:2px solid var(--olive);outline-offset:3px}
