/* ============================================================
   Bayou Quilt Co — longarm quilting
   Bayou navy + olive, Fraunces display, running-stitch motifs.
   ============================================================ */
:root{
  --linen:#f1e9d7; --linen-2:#ece2cd; --cream:#faf4e7; --paper:#fffdf8;
  --ink:#28323f; --ink-soft:#5b6470; --ink-faint:#8b8c84;
  --navy:#26384d; --navy-deep:#1a2937; --navy-soft:#ccd6df;
  --sage:#6d7551; --sage-deep:#555c3e; --sage-soft:#dde0cd;
  --line:#d9cbac; --line-soft:#e6dcc4;
  --shadow:28px 28px 60px -36px rgba(30,42,55,.42);
  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --body:"Mulish",system-ui,-apple-system,sans-serif;
  --r:14px; --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background-color:var(--linen); color:var(--ink);
  font-family:var(--body); font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(circle at 12% 8%, rgba(38,56,77,.045), transparent 40%),
    radial-gradient(circle at 88% 92%, rgba(109,117,81,.05), transparent 42%);
}
a{color:inherit}
img{display:block; max-width:100%}
::selection{background:var(--navy); color:var(--paper)}

/* entrance reveals — CSS only, never gate content behind JS */
@keyframes rise{from{opacity:0; transform:translateY(20px)}to{opacity:1; transform:none}}
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0; animation:rise .7s var(--ease) forwards; animation-delay:var(--d,0ms)}
}

/* top stitched ribbon */
.stitch-top{height:7px; background:var(--navy);
  border-bottom:2px dashed var(--paper); background-clip:padding-box}

/* ---------- header ---------- */
.site-head{
  position:sticky; top:0; z-index:60; display:flex; align-items:center; gap:26px;
  padding:14px clamp(18px,4vw,52px); background:rgba(243,235,219,.86);
  backdrop-filter:blur(10px); border-bottom:1px solid var(--line);
}
.brand{display:flex; align-items:center; gap:13px; text-decoration:none; margin-right:auto}
.brand-logo{width:50px; height:50px; flex:0 0 auto; display:block}
.brand-mark{color:var(--navy); display:flex}
.brand-name{font-family:var(--display); font-weight:600; font-size:23px; line-height:1; letter-spacing:.005em; color:var(--navy); display:inline-block;
  border-bottom:2px dashed var(--navy-soft); padding-bottom:4px}
.brand:hover .brand-name{border-bottom-color:var(--sage)}
.brand-sub{font-size:10.5px; letter-spacing:.26em; text-transform:uppercase; color:var(--ink-faint); display:block; margin-top:6px}
.site-nav{display:flex; gap:6px}
.nav-link{font-size:14.5px; font-weight:600; text-decoration:none; color:var(--ink-soft); padding:8px 14px; border-radius:999px; transition:color .2s, background .2s}
.nav-link:hover{color:var(--navy)}
.nav-link.is-active{color:var(--navy); background:var(--navy-soft)}
.head-cta{padding:9px 18px !important}
.nav-toggle{display:none; background:none; border:none; font-size:22px; color:var(--ink); cursor:pointer}

/* ---------- buttons ---------- */
.btn{display:inline-flex; align-items:center; gap:8px; font-family:var(--body); font-weight:700; font-size:15px;
  text-decoration:none; cursor:pointer; border:none; padding:13px 26px; border-radius:999px; transition:transform .2s var(--ease), box-shadow .2s, background .2s, color .2s}
.btn-primary{background:var(--navy); color:var(--paper); box-shadow:0 10px 24px -12px rgba(38,56,77,.5)}
.btn-primary:hover{background:var(--navy-deep); transform:translateY(-2px); box-shadow:0 16px 30px -12px rgba(38,56,77,.5)}
.btn-ghost{background:transparent; color:var(--ink); border:1.5px dashed var(--navy); padding:11px 24px}
.btn-ghost:hover{background:var(--navy-soft); transform:translateY(-2px)}

/* ---------- layout shells ---------- */
.main{max-width:1100px; margin:0 auto; padding:60px clamp(18px,4vw,40px) 90px}
.main-wide{max-width:1280px; margin:0 auto; padding:0 0 90px}
.band{max-width:1180px; margin:0 auto; padding:64px clamp(18px,4vw,40px)}
.band-alt{background:var(--linen-2); max-width:none; border-block:1px solid var(--line)}
.band-alt>*{max-width:1180px; margin-inline:auto}
.eyebrow{font-size:12px; font-weight:700; letter-spacing:.26em; text-transform:uppercase; color:var(--navy); margin:0 0 14px}

/* ---------- stitch divider ---------- */
.divider{display:flex; align-items:center; gap:18px; margin:0 0 38px}
.divider-line{flex:1; height:0; border-top:2px dashed var(--line)}
.divider-label{font-family:var(--display); font-style:italic; font-size:21px; color:var(--sage); white-space:nowrap}

/* ---------- hero ---------- */
.hero{position:relative; overflow:hidden; padding:clamp(70px,11vw,140px) clamp(20px,5vw,60px) clamp(80px,9vw,120px);
  background:
    linear-gradient(180deg, var(--cream), var(--linen) 90%);
  border-bottom:1px solid var(--line)}
.hero::before{content:""; position:absolute; inset:0; opacity:.5; pointer-events:none;
  background-image:linear-gradient(var(--line-soft) 1px, transparent 1px), linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size:46px 46px; -webkit-mask-image:radial-gradient(120% 80% at 80% 20%, #000, transparent 70%); mask-image:radial-gradient(120% 80% at 80% 20%, #000, transparent 70%)}
.hero-inner{position:relative; max-width:760px}
.hero-title{font-family:var(--display); font-weight:500; font-size:clamp(40px,7vw,78px); line-height:1.02; letter-spacing:-.015em; margin:0; color:var(--ink)}
.hero-lede{font-size:clamp(17px,2vw,20px); line-height:1.6; color:var(--ink-soft); margin:24px 0 0; max-width:54ch}
.hero-cta{display:flex; flex-wrap:wrap; gap:14px; margin-top:36px}
.hero-stitch{position:absolute; left:0; right:0; bottom:0; height:18px;
  background:repeating-linear-gradient(90deg, var(--navy) 0 22px, transparent 22px 40px); opacity:.18}

/* ---------- patchwork grid ---------- */
.patch-grid{display:grid; grid-template-columns:repeat(12,1fr); gap:16px; grid-auto-flow:dense}
.home-grid{padding-top:6px}
.patch{position:relative; overflow:hidden; border-radius:var(--r); border:1px solid var(--line);
  background:var(--cream); box-shadow:0 14px 34px -22px rgba(70,45,25,.55); text-decoration:none; color:inherit;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease); margin:0}
.patch::after{content:""; position:absolute; inset:7px; border:1.5px dashed rgba(255,253,248,.7); border-radius:9px; pointer-events:none; opacity:0; transition:opacity .3s}
.patch:hover{transform:translateY(-5px); box-shadow:0 26px 46px -22px rgba(70,45,25,.6)}
.patch:hover::after{opacity:1}
.patch img{width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease)}
.patch:hover img{transform:scale(1.05)}
.patch-cap{position:absolute; left:12px; bottom:11px; right:12px; z-index:2; color:#fff; font-family:var(--display); font-style:italic; font-size:18px; text-shadow:0 2px 10px rgba(0,0,0,.6)}
.patch figcaption{position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:14px;
  background:linear-gradient(to top, rgba(45,39,34,.78), transparent 55%); opacity:0; transition:opacity .3s; cursor:pointer}
.patch:hover figcaption{opacity:1}
.patch-cat{color:var(--navy-soft); font-size:11px; letter-spacing:.16em; text-transform:uppercase; margin-top:4px; position:relative; z-index:2}
/* tile spans → patchwork rhythm */
.patch-1{grid-column:span 5; aspect-ratio:4/5}
.patch-2{grid-column:span 4; aspect-ratio:1/1}
.patch-3{grid-column:span 3; aspect-ratio:3/4}
.patch-4{grid-column:span 4; aspect-ratio:4/5}
.patch-5{grid-column:span 5; aspect-ratio:5/4}
.gallery-grid .patch figcaption{opacity:1; background:linear-gradient(to top, rgba(45,39,34,.72), transparent 48%)}
.gallery-grid .patch .patch-cap{position:static; text-shadow:none}
.gallery-grid figcaption{justify-content:flex-end}

.center-link{text-align:center; margin-top:34px}
.link-stitch{color:var(--navy); font-weight:700; text-decoration:none; border-bottom:2px dashed var(--navy); padding-bottom:2px; transition:color .2s, border-color .2s}
.link-stitch:hover{color:var(--navy-deep)}
.empty-note{text-align:center; font-family:var(--display); font-style:italic; font-size:21px; color:var(--sage); padding:50px 20px; border:2px dashed var(--line); border-radius:var(--r)}

/* ---------- two-col / steps ---------- */
.two-col{display:grid; grid-template-columns:1fr 1.1fr; gap:50px; align-items:start}
.section-title{font-family:var(--display); font-weight:500; font-size:clamp(28px,3.4vw,40px); line-height:1.1; margin:0; letter-spacing:-.01em}
.steps{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:22px}
.steps li{display:flex; gap:18px; align-items:flex-start}
.step-no{flex:0 0 auto; width:42px; height:42px; border-radius:50%; background:var(--cream); border:2px dashed var(--navy);
  color:var(--navy); font-family:var(--display); font-size:20px; font-weight:600; display:flex; align-items:center; justify-content:center}
.steps strong{font-family:var(--display); font-size:20px; font-weight:600}
.steps p{margin:4px 0 0; color:var(--ink-soft); font-size:15.5px}

/* ---------- cta band ---------- */
.cta-band{background:var(--navy); color:var(--paper); position:relative; overflow:hidden}
.cta-band::before{content:""; position:absolute; inset:0; opacity:.16;
  background:repeating-linear-gradient(45deg, var(--paper) 0 2px, transparent 2px 16px)}
.cta-inner{position:relative; max-width:760px; margin:0 auto; text-align:center; padding:72px 24px}
.cta-inner h2{font-family:var(--display); font-weight:500; font-size:clamp(28px,4vw,44px); margin:0 0 8px}
.cta-inner p{margin:0 0 28px; color:rgba(255,253,248,.85); font-size:18px}
.cta-band .btn-primary{background:var(--paper); color:var(--navy-deep)}
.cta-band .btn-primary:hover{background:#fff}

/* ---------- page heads ---------- */
.page-head{max-width:1180px; margin:0 auto; padding:clamp(48px,7vw,88px) clamp(18px,4vw,40px) 30px}
.page-title{font-family:var(--display); font-weight:500; font-size:clamp(36px,5.5vw,62px); line-height:1.04; letter-spacing:-.018em; margin:0}
.page-lede{font-size:18px; color:var(--ink-soft); max-width:60ch; margin:18px 0 0}
.gallery-grid,.services-grid{max-width:1180px; margin:0 auto; padding:18px clamp(18px,4vw,40px) 0}

/* gallery filters */
.gal-filters{max-width:1180px; margin:6px auto 22px; padding:0 clamp(18px,4vw,40px); display:flex; flex-wrap:wrap; gap:9px}
.chip{font-family:var(--body); font-weight:600; font-size:13px; cursor:pointer; padding:8px 16px; border-radius:999px;
  background:var(--cream); border:1.5px solid var(--line); color:var(--ink-soft); transition:all .2s}
.chip:hover{border-color:var(--navy); color:var(--navy)}
.chip.is-active{background:var(--navy); border-color:var(--navy); color:var(--paper)}

/* empty gallery */
.empty-state{max-width:640px; margin:30px auto 0; text-align:center; padding:60px 30px; background:var(--cream); border:2px dashed var(--line); border-radius:var(--r)}
.empty-stitch{width:80px; height:80px; margin:0 auto 22px; border-radius:50%; border:3px dashed var(--navy);
  background:repeating-conic-gradient(var(--navy-soft) 0 30deg, transparent 30deg 60deg)}
.empty-state h2{font-family:var(--display); font-weight:500; font-size:28px; margin:0 0 10px}
.empty-state p{color:var(--ink-soft); margin:0}

/* ---------- services ---------- */
.services-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:22px}
.service-card{position:relative; background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:30px 26px 26px; overflow:hidden}
.service-card::before{content:""; position:absolute; inset:8px; border:1.5px dashed var(--line); border-radius:9px; pointer-events:none}
.service-corner{position:absolute; top:0; right:0; width:46px; height:46px; background:var(--navy-soft);
  clip-path:polygon(100% 0,0 0,100% 100%)}
.service-card h3{font-family:var(--display); font-weight:600; font-size:24px; margin:0 0 10px; position:relative}
.service-card p{color:var(--ink-soft); font-size:15px; margin:0 0 16px; position:relative}
.service-price{position:relative; font-family:var(--body); font-weight:700; font-size:13px; letter-spacing:.04em; color:var(--navy);
  background:var(--paper); border:1.5px dashed var(--navy); border-radius:999px; padding:5px 14px; display:inline-block}

.note-card{background:var(--sage-soft); border:1px solid #c3cebb; border-radius:var(--r); padding:28px 30px; max-width:760px}
.note-tag{font-family:var(--body); font-weight:700; font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--sage); display:block; margin-bottom:8px}
.note-card p{margin:0; color:#3f4a3b; font-size:16px}

/* ---------- intake form ---------- */
.intake{max-width:900px; margin:0 auto; padding:64px clamp(18px,4vw,40px) 20px}
.intake-head{text-align:center; margin-bottom:30px}
.intake-head h2{font-family:var(--display); font-weight:500; font-size:clamp(28px,4vw,40px); margin:0 0 8px}
.intake-head p{color:var(--ink-soft); margin:0 auto; max-width:52ch}
.intake-form{background:var(--paper); border:1px solid var(--line); border-radius:18px; padding:clamp(22px,3vw,38px); box-shadow:var(--shadow)}
.field{display:flex; flex-direction:column; gap:7px; margin-bottom:18px}
.field>span{font-size:13px; font-weight:700; letter-spacing:.03em; color:var(--ink-soft)}
.field em{color:var(--navy); font-style:normal}
.field input,.field select,.field textarea{font-family:var(--body); font-size:16px; color:var(--ink); background:var(--cream);
  border:1.5px solid var(--line); border-radius:10px; padding:12px 14px; transition:border-color .2s, box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--navy); box-shadow:0 0 0 4px var(--navy-soft)}
.field textarea{resize:vertical; line-height:1.55}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.field-group{border:none; border-top:2px dashed var(--line); margin:8px 0 4px; padding:22px 0 0}
.field-group legend{font-family:var(--display); font-style:italic; font-size:20px; color:var(--sage); padding:0 12px 0 0}
.field-sm input{width:100%}
.calc{justify-content:flex-start}
.calc output{font-family:var(--display); font-size:20px; color:var(--navy); padding:8px 0}
.check{display:flex; align-items:center; gap:9px; font-size:15px; font-weight:600; color:var(--ink-soft); cursor:pointer}
.form-foot{display:flex; flex-wrap:wrap; align-items:center; gap:16px; margin-top:8px}
.form-note{font-size:13.5px; color:var(--ink-faint)}
input[type=file]{padding:9px; background:var(--cream); cursor:pointer}

/* ---------- about ---------- */
.about{max-width:1100px; margin:0 auto; padding:clamp(40px,6vw,80px) clamp(18px,4vw,40px)}
.about-grid{display:grid; grid-template-columns:.85fr 1fr; gap:54px; align-items:center}
.about-frame{position:relative; background:var(--paper); padding:14px; border:1px solid var(--line); border-radius:6px;
  box-shadow:var(--shadow); transform:rotate(-2deg)}
.about-frame img{width:100%; border-radius:3px; aspect-ratio:4/5; object-fit:cover}
.about-tape{position:absolute; width:96px; height:30px; background:rgba(189,134,58,.32); border:1px dashed rgba(143,61,38,.4)}
.about-tape-1{top:-14px; left:24px; transform:rotate(-6deg)}
.about-tape-2{bottom:-14px; right:30px; transform:rotate(5deg)}
.about-cap{text-align:center; font-family:var(--display); font-style:italic; color:var(--sage); margin-top:24px}
.prose{color:var(--ink-soft); font-size:17px}
.prose+.btn{margin-top:26px}
.about-text .page-title{margin-bottom:18px}

/* ---------- shop coming soon ---------- */
.shop-soon{display:flex; align-items:center; justify-content:center; min-height:62vh; padding:60px 24px; text-align:center}
.shop-inner{max-width:560px}
.shop-spool{width:90px; height:90px; margin:0 auto 26px; border-radius:50%;
  background:radial-gradient(circle at 50% 50%, var(--cream) 26%, var(--navy) 27% 33%, var(--cream) 34% 46%, var(--navy) 47% 53%, var(--cream) 54%);
  border:3px dashed var(--navy)}
.shop-inner .page-lede{margin:14px auto 28px}

/* ---------- thank you / 404 ---------- */
.thanks{display:flex; align-items:center; justify-content:center; min-height:60vh; padding:60px 24px; text-align:center}
.thanks-inner{max-width:560px}
.thanks-check{width:74px; height:74px; margin:0 auto 22px; border-radius:50%; background:var(--sage); color:#fff;
  font-size:38px; display:flex; align-items:center; justify-content:center; box-shadow:0 12px 28px -12px rgba(94,110,88,.8)}
.thanks-cta{display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:28px}

/* ---------- lightbox ---------- */
.lightbox{position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center; padding:5vh 4vw;
  background:rgba(40,32,26,.9); backdrop-filter:blur(8px)}
.lightbox[hidden]{display:none}
.lb-figure{margin:0; max-width:min(960px,92vw); text-align:center}
.lb-figure img{max-height:78vh; width:auto; margin:0 auto; border-radius:8px; border:8px solid var(--paper); box-shadow:0 30px 80px -20px rgba(0,0,0,.7)}
.lb-figure figcaption{color:var(--paper); font-family:var(--display); font-style:italic; font-size:20px; margin-top:18px}
.lb-close{position:fixed; top:22px; right:26px; width:46px; height:46px; border-radius:50%; border:1.5px dashed var(--paper);
  background:transparent; color:var(--paper); font-size:18px; cursor:pointer; transition:background .2s}
.lb-close:hover{background:rgba(255,255,255,.15)}

/* ---------- footer ---------- */
.site-foot{background:var(--ink); color:#e9ddca; margin-top:30px}
.foot-inner{max-width:1180px; margin:0 auto; display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px; padding:54px clamp(18px,4vw,40px) 40px}
.foot-name{font-family:var(--display); font-size:23px; color:var(--paper); margin-bottom:8px}
.foot-brand p{color:#b9ab95; margin:0; max-width:34ch}
.foot-links{display:flex; flex-direction:column; gap:10px}
.foot-links a,.foot-contact a,.foot-contact span{color:#ccbfa8; text-decoration:none; transition:color .2s}
.foot-links a:hover,.foot-contact a:hover{color:var(--navy-soft)}
.foot-contact{display:flex; flex-direction:column; gap:10px}
.foot-base{border-top:1px dashed #4a4036; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
  max-width:1180px; margin:0 auto; padding:18px clamp(18px,4vw,40px); font-size:13px; color:#9b8d77}
.foot-admin{color:#9b8d77; text-decoration:none; border-bottom:1px dashed #6a5e4e}
.foot-admin:hover{color:var(--navy-soft)}

/* ---------- login ---------- */
.login{display:flex; align-items:center; justify-content:center; min-height:74vh; padding:40px 20px}
.login-card{width:min(420px,100%); background:var(--paper); border:1px solid var(--line); border-radius:18px; padding:38px 34px; text-align:center; box-shadow:var(--shadow)}
.login-spool{width:64px; height:64px; margin:0 auto 18px; border-radius:50%;
  background:radial-gradient(circle, var(--cream) 30%, var(--navy) 31% 40%, var(--cream) 41%); border:3px dashed var(--navy)}
.login-card h1{font-family:var(--display); font-weight:500; font-size:30px; margin:0 0 4px}
.login-card>p{color:var(--ink-soft); margin:0 0 22px}
.login-card .field{text-align:left}
.login-card .btn{width:100%; justify-content:center; margin-top:4px}
.login-err{background:var(--navy-soft); color:var(--navy-deep); border-radius:8px; padding:9px; font-size:14px; font-weight:600; margin:0 0 16px}
.login-back{display:inline-block; margin-top:18px; color:var(--ink-faint); text-decoration:none; font-size:14px}
.login-back:hover{color:var(--navy)}

/* ---------- admin ---------- */
.admin{max-width:1080px; margin:0 auto; padding:40px clamp(18px,4vw,40px) 80px}
.adm-head{display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:16px; margin-bottom:30px}
.adm-head h1{font-family:var(--display); font-weight:500; font-size:34px; margin:4px 0 0}
.adm-head-actions{display:flex; gap:10px; align-items:center}
.adm-head-actions form{margin:0}
.adm-tabs{display:flex; gap:8px; border-bottom:2px dashed var(--line); margin-bottom:28px; flex-wrap:wrap}
.adm-tab{font-family:var(--body); font-weight:700; font-size:15px; cursor:pointer; background:none; border:none; color:var(--ink-soft);
  padding:12px 18px; border-bottom:3px solid transparent; margin-bottom:-2px; display:flex; align-items:center; gap:8px}
.adm-tab span{background:var(--line-soft); color:var(--ink-soft); font-size:12px; padding:1px 8px; border-radius:999px}
.adm-tab .badge{background:var(--navy); color:#fff}
.adm-tab.is-active{color:var(--navy); border-color:var(--navy)}
.adm-panel{display:none}
.adm-panel.is-active{display:block; animation:rise .4s var(--ease)}
.adm-panel h2{font-family:var(--display); font-weight:500; font-size:26px; margin:0 0 18px}
.adm-sub{margin-top:42px !important}
.adm-hint{color:var(--ink-soft); margin:-10px 0 20px; font-size:15px}
.adm-empty{color:var(--ink-faint); font-style:italic; list-style:none; padding:20px 0}

/* upload */
.adm-upload{background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:26px; margin-bottom:10px}
.adm-upload-grid{display:grid; grid-template-columns:260px 1fr; gap:26px; align-items:start}
.drop{position:relative; display:flex; align-items:center; justify-content:center; aspect-ratio:4/5; border:2px dashed var(--navy);
  border-radius:12px; background:var(--paper); cursor:pointer; overflow:hidden}
.drop input{position:absolute; inset:0; opacity:0; cursor:pointer}
.drop-inner{display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--navy)}
.drop-icon{font-size:34px}
.drop-text{font-weight:700; font-size:14px}
.drop-preview{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
.adm-upload-fields{display:flex; flex-direction:column}
.adm-upload-fields .btn{align-self:flex-start; margin-top:6px}

/* quilt list */
.adm-quilts{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px}
.adm-quilt-row{display:flex; gap:14px; align-items:center; background:var(--cream); border:1px solid var(--line); border-radius:12px; padding:12px 14px}
.adm-quilt-row>img{width:52px; height:66px; object-fit:cover; border-radius:7px; flex:0 0 auto}
.adm-quilt-meta{flex:1; min-width:0}
.adm-quilt-meta strong{display:block; font-family:var(--display); font-size:17px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.adm-quilt-meta span{font-size:12.5px; color:var(--ink-faint)}
.adm-quilt-row>.mini{flex:0 0 auto; width:auto}

/* native dialog edit modal — can't disturb the list layout */
.edit-modal{width:min(460px,94vw); max-height:90vh; margin:auto; border:1px solid var(--line); border-radius:16px;
  padding:26px; background:var(--paper); color:var(--ink); box-shadow:0 40px 90px -30px rgba(20,28,38,.7)}
.edit-modal::backdrop{background:rgba(26,41,55,.55); backdrop-filter:blur(3px)}
.edit-modal-head{display:flex; align-items:center; gap:14px; margin-bottom:18px}
.edit-modal-head img{width:46px; height:58px; object-fit:cover; border-radius:7px}
.edit-noimg{width:46px; height:58px; display:flex; align-items:center; justify-content:center; background:var(--cream); border:1px dashed var(--line); border-radius:7px; color:var(--line); font-size:22px; flex:0 0 auto}
.edit-modal-head h3{font-family:var(--display); font-style:italic; font-size:25px; margin:0}
.edit-modal .field{margin-bottom:14px}
.modal-actions{display:flex; gap:10px; justify-content:flex-end; margin-top:4px}
.modal-actions .btn{padding:11px 20px}
.modal-extra{display:flex; gap:10px; margin-top:18px; padding-top:16px; border-top:1px dashed var(--line)}
.modal-extra form{margin:0}
.modal-extra .mini{width:auto}
.mini{font-family:var(--body); font-weight:600; font-size:12px; cursor:pointer; background:var(--paper); border:1.5px solid var(--line);
  color:var(--ink-soft); padding:6px 11px; border-radius:999px; transition:all .2s; white-space:nowrap; width:100%}
.mini:hover{border-color:var(--navy); color:var(--navy)}
.mini.danger:hover{border-color:#b3261e; color:#b3261e}

/* intake inbox */
.adm-intakes{display:flex; flex-direction:column; gap:10px}
.adm-intake{background:var(--cream); border:1px solid var(--line); border-radius:12px; overflow:hidden}
.adm-intake.is-unread{border-color:var(--navy); box-shadow:0 0 0 1px var(--navy-soft)}
.adm-intake summary{display:flex; align-items:center; gap:14px; padding:15px 18px; cursor:pointer; list-style:none}
.adm-intake summary::-webkit-details-marker{display:none}
.adm-int-name{font-family:var(--display); font-size:18px; font-weight:600}
.adm-int-sub{color:var(--ink-soft); font-size:14px; flex:1}
.adm-int-date{color:var(--ink-faint); font-size:13px}
.adm-intake.is-unread summary .adm-int-name::after{content:"new"; margin-left:9px; font-family:var(--body); font-size:10px; letter-spacing:.1em; text-transform:uppercase; background:var(--navy); color:#fff; padding:2px 7px; border-radius:999px; vertical-align:middle}
.adm-int-body{padding:4px 18px 18px; border-top:1px dashed var(--line)}
.adm-int-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:10px 22px; margin:14px 0}
.kv{display:flex; flex-direction:column}
.kv dt{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint)}
.kv dd{margin:2px 0 0; font-size:15px}
.kv dd a{color:var(--navy)}
.adm-int-notes{background:var(--paper); border:1px dashed var(--line); border-radius:10px; padding:12px 14px; margin:6px 0}
.adm-int-notes span{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint)}
.adm-int-notes p{margin:6px 0 0}
.adm-int-photo img{max-width:180px; border-radius:8px; border:4px solid var(--paper); box-shadow:var(--shadow); margin-top:8px}
.adm-int-actions{display:flex; gap:10px; margin-top:14px}
.adm-int-actions form{margin:0}
.adm-int-actions .mini{width:auto}

/* settings */
.adm-settings{max-width:680px}
.adm-settings .btn{margin-top:8px}

/* ---------- home banner masthead ---------- */
.hero-banner{display:flex; flex-direction:column; align-items:center; text-align:center;
  padding:clamp(36px,5vw,68px) clamp(20px,5vw,60px) clamp(64px,7vw,96px)}
.masthead{width:100%; max-width:1000px; height:auto; border-radius:12px;
  box-shadow:0 30px 64px -40px rgba(30,42,55,.5)}
.hero-banner .hero-title{font-size:clamp(28px,4vw,46px); margin:38px 0 0}
.hero-banner .hero-lede{margin-left:auto; margin-right:auto}
.hero-banner .hero-cta{justify-content:center}

/* ---------- brand kit page ---------- */
.brand-wrap{max-width:1100px; margin:0 auto; padding:10px clamp(18px,4vw,40px) 40px}
.brand-wrap .divider{margin-top:44px}
.brand-logos{display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:20px}
.brand-card{margin:0 0 20px; background:var(--cream); border:1px solid var(--line); border-radius:var(--r); overflow:hidden}
.brand-hero .brand-show{padding:34px clamp(20px,4vw,56px); min-height:0}
.brand-hero .brand-show img{max-width:760px; width:100%}
.brand-show{display:flex; align-items:center; justify-content:center; padding:26px; min-height:190px}
.brand-show.light{background:var(--paper)}
.brand-show.dark{background:var(--navy)}
.brand-show img{max-width:100%; max-height:160px}
.bc-round{width:150px; height:150px; border-radius:50%; box-shadow:0 10px 26px -16px rgba(30,42,55,.5)}
.bc-avatar{width:118px; height:118px; border-radius:50%; object-fit:cover; box-shadow:0 8px 20px -12px rgba(30,42,55,.5)}
.brand-card figcaption{display:flex; justify-content:space-between; align-items:center; gap:10px; padding:13px 16px;
  font-family:var(--body); font-size:13.5px; font-weight:600; color:var(--ink-soft); border-top:1px dashed var(--line)}
.brand-card figcaption a{font-family:var(--mono,monospace); font-size:11px; letter-spacing:.04em; text-transform:uppercase;
  color:var(--navy); border-bottom:1.5px dashed var(--navy); text-decoration:none}

.brand-colors{display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:16px}
.sw{display:flex; flex-direction:column; gap:3px; background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:14px}
.sw-chip{height:64px; border-radius:8px; border:1px solid rgba(0,0,0,.08); margin-bottom:8px}
.sw-name{font-family:var(--display); font-weight:600; font-size:18px}
.sw-hex{font-family:monospace; font-size:13px; color:var(--ink-soft); letter-spacing:.04em}
.sw-sub{font-size:12px; color:var(--ink-faint)}

.brand-type{display:grid; grid-template-columns:1fr 1fr; gap:20px}
.type-card{background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:26px}
.type-tag{font-family:monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--navy); display:block; margin-bottom:14px}
.type-sample{margin:0 0 6px; font-size:34px; line-height:1.1; color:var(--ink)}
.type-sample.sm{font-size:18px; color:var(--ink-soft)}
.type-note{font-size:13px; color:var(--ink-faint)}

.brand-motif{display:flex; align-items:center; gap:28px; background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:28px 30px}
.motif-show{flex:0 0 120px}
.motif-dash{display:block; height:0; border-top:3px dashed var(--navy); width:120px}
.motif-text h3{font-family:var(--display); font-weight:600; font-size:22px; margin:0 0 6px}
.motif-text p{margin:0; color:var(--ink-soft); font-size:15px}
.foot-meta{display:flex; gap:18px}

/* header mark (geometric star) */
.brand-mark{width:44px; height:44px; flex:0 0 auto; display:block}

/* decorative star strip */
.star-strip{display:flex; justify-content:center; gap:20px; padding:8px 0 2px; overflow:hidden; opacity:.45; max-width:1100px; margin:0 auto}
.star-strip img{width:24px; height:24px; flex:0 0 auto}

/* the mark section */
.mark-row{display:grid; grid-template-columns:auto auto 1fr; gap:22px; align-items:center}
.mark-card{width:158px; height:158px; border-radius:var(--r); display:flex; align-items:center; justify-content:center; border:1px solid var(--line)}
.mark-card.light{background:var(--paper)}
.mark-card.navy{background:var(--navy); border-color:var(--navy)}
.mark-card img{width:110px; height:110px}
.mark-note h3{font-family:var(--display); font-weight:600; font-size:23px; margin:0 0 8px}
.mark-note p{margin:0 0 12px; color:var(--ink-soft); font-size:15px; max-width:48ch}

/* collateral mockups */
.collateral{display:flex; flex-wrap:wrap; gap:34px; align-items:flex-start}
.biz{display:flex; gap:18px; flex-wrap:wrap}
.biz-card{width:300px; height:172px; border-radius:12px; box-shadow:0 18px 40px -22px rgba(30,42,55,.55);
  display:flex; flex-direction:column; padding:20px; position:relative; overflow:hidden}
.biz-front{background:var(--navy); align-items:center; justify-content:center; text-align:center; gap:4px}
.biz-front::after{content:""; position:absolute; inset:9px; border:1.5px dashed rgba(250,244,231,.28); border-radius:8px; pointer-events:none}
.biz-star{width:56px; height:56px; margin-bottom:6px}
.biz-name{font-family:var(--display); font-weight:600; font-size:24px; color:var(--paper)}
.biz-tag{font-family:var(--body); font-size:9.5px; letter-spacing:.22em; text-transform:uppercase; color:#c7d0c0}
.biz-back{background:var(--paper); justify-content:center; gap:3px}
.biz-back-name{font-family:var(--display); font-weight:600; font-size:21px; color:var(--navy)}
.biz-back-role{font-family:var(--body); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--sage); margin-bottom:8px}
.biz-back-line{font-size:13px; color:var(--ink-soft)}
.biz-back-dash{display:block; height:0; border-top:2px dashed var(--line); width:60px; margin:9px 0 7px}
.biz-back-foot{font-size:11px; color:var(--ink-faint)}

.label-tag{width:230px; background:var(--paper); border:2px solid var(--navy); border-radius:7px; padding:18px 16px;
  display:flex; flex-direction:column; align-items:center; text-align:center; box-shadow:0 14px 32px -20px rgba(30,42,55,.5)}
.label-top,.label-bottom{font-family:var(--body); font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--sage)}
.label-star{width:42px; height:42px; margin:9px 0}
.label-name{font-family:var(--display); font-weight:600; font-size:21px; color:var(--navy); margin-bottom:8px}
.label-cap{text-align:center; font-family:var(--body); font-size:12.5px; color:var(--ink-faint); margin:12px 0 0}

@media (max-width:620px){ .brand-type{grid-template-columns:1fr} .mark-row{grid-template-columns:1fr 1fr} .mark-note{grid-column:1/-1} }

/* ---------- quilt prep ---------- */
.prep{max-width:820px; margin:0 auto; padding:10px clamp(18px,4vw,40px) 20px}
.prep-list{list-style:none; margin:0 0 36px; padding:0; display:flex; flex-direction:column; gap:18px}
.prep-step{display:flex; gap:18px; align-items:flex-start}
.prep-no{flex:0 0 auto; width:40px; height:40px; border-radius:50%; background:var(--cream); border:2px dashed var(--navy); color:var(--navy); font-family:var(--display); font-size:19px; font-weight:600; display:flex; align-items:center; justify-content:center}
.prep-step strong{font-family:var(--display); font-size:20px; font-weight:600}
.prep-step p{margin:4px 0 0; color:var(--ink-soft); font-size:15.5px; line-height:1.55}
.prep-cta{display:flex; flex-direction:column; align-items:flex-start; gap:18px}
.prep-cta .note-card{max-width:none}

/* ---------- price estimator ---------- */
.estimator-band{max-width:1180px; margin:0 auto; padding:10px clamp(18px,4vw,40px) 0}
.estimator{background:var(--navy); color:var(--paper); border-radius:var(--r); padding:clamp(24px,4vw,40px); position:relative; overflow:hidden}
.estimator::before{content:""; position:absolute; inset:0; opacity:.1; background:repeating-linear-gradient(45deg, var(--paper) 0 2px, transparent 2px 16px)}
.est-head{position:relative; max-width:62ch}
.est-head .eyebrow{color:var(--sage-soft)}
.est-head h2{font-family:var(--display); font-weight:500; font-size:clamp(23px,3vw,32px); margin:0 0 8px}
.est-head p{color:rgba(250,244,231,.82); margin:0; font-size:15px; line-height:1.5}
.est-form{position:relative; display:flex; align-items:flex-end; gap:16px; flex-wrap:wrap; margin:22px 0 14px}
.est-form .field{margin:0}
.est-form .field>span{color:var(--sage-soft)}
.est-form input{background:rgba(255,253,248,.96); border-color:transparent; width:118px}
.est-x{font-family:var(--display); font-size:22px; color:var(--sage-soft); padding-bottom:12px}
.est-out{margin-left:auto; text-align:right; display:flex; flex-direction:column}
.est-out-label{font-family:monospace; font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--sage-soft)}
.est-out-val{font-family:var(--display); font-weight:500; font-size:clamp(30px,4vw,44px); line-height:1; color:#fff}
.est-out-sub{font-size:12px; color:rgba(250,244,231,.7); margin-top:4px}
.est-note{position:relative; font-size:13px; color:rgba(250,244,231,.6); margin:0}
@media (max-width:560px){ .est-out{margin-left:0; text-align:left; margin-top:8px} }

/* ============================================================
   SHOP
   ============================================================ */
.head-cart{position:relative; display:inline-flex; align-items:center; font-size:20px; text-decoration:none; padding:4px 6px; line-height:1}
.head-cart-n{position:absolute; top:-4px; right:-6px; background:var(--navy); color:var(--paper); font-family:var(--body); font-weight:700; font-size:10px; min-width:17px; height:17px; border-radius:999px; display:flex; align-items:center; justify-content:center; padding:0 4px}

.shop-grid{max-width:1240px; margin:0 auto; padding:14px clamp(16px,3vw,36px) 0; display:grid; grid-template-columns:repeat(auto-fill,minmax(158px,1fr)); gap:14px}
.prod-card{display:block; text-decoration:none; color:inherit; background:var(--cream); border:1px solid var(--line); border-radius:10px; overflow:hidden; transition:border-color .2s var(--ease), transform .2s var(--ease), box-shadow .2s var(--ease)}
.prod-card:hover{transform:translateY(-3px); border-color:var(--navy-soft); box-shadow:0 14px 30px -18px rgba(30,42,55,.45)}
.prod-photo{position:relative; aspect-ratio:1/1; background:var(--bg-2,#efe7d3); overflow:hidden}
.prod-photo img{width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease)}
.prod-card:hover .prod-photo img{transform:scale(1.04)}
.prod-noimg{width:100%; height:100%; display:flex; align-items:center; justify-content:center; color:var(--line); font-size:38px}
.prod-noimg.big{aspect-ratio:1/1; font-size:90px}
.prod-sold{position:absolute; top:8px; left:8px; background:var(--navy); color:var(--paper); font-family:var(--mono,monospace); font-size:9px; letter-spacing:.08em; text-transform:uppercase; padding:3px 8px; border-radius:999px}
.prod-info{padding:9px 11px 11px; display:flex; flex-direction:column; gap:1px}
.prod-cat{font-family:monospace; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--sage)}
.prod-name{font-family:var(--display); font-weight:600; font-size:14.5px; line-height:1.18; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.prod-price{font-family:var(--body); font-weight:700; font-size:13px; color:var(--navy); margin-top:3px}
.prod-price em{font-style:normal; font-weight:600; font-size:10.5px; color:var(--ink-faint)}
@media (max-width:520px){ .shop-grid{grid-template-columns:repeat(2,1fr); gap:11px} }

.prod-detail{max-width:1080px; margin:0 auto; padding:8px clamp(18px,4vw,40px) 20px; display:grid; grid-template-columns:1fr 1fr; gap:44px; align-items:start}
.prod-detail-photo > img, .prod-detail-photo .prod-noimg.big{width:100%; aspect-ratio:1/1; object-fit:cover; display:block; border-radius:var(--r); border:1px solid var(--line); box-shadow:var(--shadow); background:var(--cream)}
.prod-thumbs{display:flex; gap:8px; margin-top:10px; flex-wrap:wrap}
.prod-thumb{width:58px; height:58px; border-radius:8px; overflow:hidden; border:2px solid transparent; padding:0; cursor:pointer; background:none}
.prod-thumb img{width:100%; height:100%; object-fit:cover}
.prod-thumb.on{border-color:var(--navy)}
.edit-photos{display:flex; flex-wrap:wrap; gap:8px}
.edit-photo{position:relative; width:54px; height:54px; border-radius:7px; overflow:hidden}
.edit-photo img{width:100%; height:100%; object-fit:cover; display:block}
.edit-photo-x{position:absolute; top:2px; right:2px; width:18px; height:18px; border-radius:50%; background:rgba(26,41,55,.8); color:#fff; font-size:9px; line-height:1; display:flex; align-items:center; justify-content:center}
.edit-photo-x:hover{background:#dc2626}
.prod-detail-info h1{font-family:var(--display); font-weight:500; font-size:clamp(28px,4vw,42px); line-height:1.05; margin:6px 0 12px}
.prod-detail-price{font-family:var(--body); font-weight:700; font-size:22px; color:var(--navy)}
.prod-detail-price em{font-style:normal; font-weight:600; font-size:14px; color:var(--ink-faint)}
.prod-stock{font-family:monospace; font-size:12px; letter-spacing:.04em; color:var(--sage); margin:8px 0 18px}
.prod-stock.out{color:#b3261e}
.prod-desc{color:var(--ink-soft); line-height:1.6; margin-bottom:22px}
.prod-add{display:flex; align-items:flex-end; gap:14px; flex-wrap:wrap}
.prod-add .field{margin:0; min-width:150px}
.prod-soldmsg{color:var(--ink-soft)}
.prod-variants{margin-bottom:18px}
.prod-var-label{display:block; font-size:13px; font-weight:700; color:var(--ink-soft); margin-bottom:8px}
.prod-var-opts{display:flex; flex-wrap:wrap; gap:8px}
.prod-var{display:inline-flex; align-items:center; gap:7px; font-size:14px; padding:8px 14px; border:1.5px solid var(--line); border-radius:999px; cursor:pointer; background:var(--cream); transition:border-color .15s, background .15s}
.prod-var input{accent-color:var(--navy); margin:0}
.prod-var:has(input:checked){border-color:var(--navy); background:var(--navy-soft)}
.prod-var.out{opacity:.5; cursor:not-allowed; text-decoration:line-through}

/* cart */
.cart-wrap{max-width:1000px; margin:0 auto; padding:0 clamp(18px,4vw,40px); display:grid; grid-template-columns:1fr 300px; gap:34px; align-items:start}
.cart-note{max-width:1000px; margin:0 auto 18px; padding:12px 18px; background:var(--sage-soft); border:1px solid #c3cebb; border-radius:var(--r-sm,10px); color:#3f4a3b; font-size:14px}
.cart-lines{display:flex; flex-direction:column; gap:12px}
.cart-line{display:flex; align-items:center; gap:14px; background:var(--cream); border:1px solid var(--line); border-radius:12px; padding:12px}
.cart-thumb{width:60px; height:60px; flex:0 0 auto; border-radius:8px; overflow:hidden; background:var(--paper)}
.cart-thumb img{width:100%; height:100%; object-fit:cover}
.cart-line-info{flex:1; min-width:0}
.cart-line-name{display:block; font-family:var(--display); font-size:17px}
.cart-line-unit{font-size:12.5px; color:var(--ink-faint)}
.cart-qty input{width:64px; padding:8px; text-align:center; font-family:var(--body); border:1.5px solid var(--line); border-radius:8px; background:var(--paper)}
.cart-line-total{font-weight:700; color:var(--navy); min-width:64px; text-align:right}
.cart-x{width:28px; height:28px; border-radius:50%; color:var(--ink-faint); font-size:13px; flex:0 0 auto}
.cart-x:hover{background:#dc2626; color:#fff}
.cart-summary{position:sticky; top:96px; background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:22px}
.cart-row{display:flex; justify-content:space-between; align-items:baseline; font-size:16px; margin-bottom:12px}
.cart-row strong{font-family:var(--display); font-size:22px}
.cart-ship-note{font-size:12.5px; color:var(--ink-faint); line-height:1.5; margin:0 0 16px}
.cart-summary .btn{width:100%}
.cart-keep{display:block; text-align:center; margin-top:14px; font-size:13px; color:var(--ink-soft); text-decoration:none}
.cart-keep:hover{color:var(--navy)}
.order-ref{font-family:monospace; color:var(--ink-faint); font-size:13px; margin-top:8px}

/* admin: order items + hidden product */
.order-items{margin:6px 0 4px; border-top:1px dashed var(--line); border-bottom:1px dashed var(--line); padding:8px 0}
.order-item{display:flex; justify-content:space-between; font-size:14px; padding:3px 0}
.adm-quilt-row.is-off{opacity:.6}

@media (max-width:760px){ .prod-detail{grid-template-columns:1fr; gap:24px} .cart-wrap{grid-template-columns:1fr} }

/* ---------- "being stitched" loader ---------- */
.stitch-loader{position:fixed; inset:0; z-index:300; display:none; flex-direction:column; align-items:center; justify-content:center; gap:18px;
  background:rgba(243,235,219,.93); backdrop-filter:blur(4px)}
.stitch-loader.show{display:flex; animation:rise .25s var(--ease)}
.stitch-loader svg{width:120px; height:120px}
.stitch-loader path{fill:none; stroke:var(--navy); stroke-width:3.4; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:1; stroke-dashoffset:1; animation:stitchdraw 2.1s var(--ease) infinite}
.stitch-loader .needle{fill:var(--navy-deep)}
@keyframes stitchdraw{0%{stroke-dashoffset:1}48%{stroke-dashoffset:0}60%{stroke-dashoffset:0}100%{stroke-dashoffset:-1}}
.stitch-loader span{font-family:var(--display); font-style:italic; font-size:22px; color:var(--sage); letter-spacing:.01em}
@media (prefers-reduced-motion:reduce){.stitch-loader path{animation:none; stroke-dashoffset:0}}

/* about photo when a real photo is set */
.about-frame img.is-photo{aspect-ratio:4/5; object-position:62% 38%}
.about-photo-form{background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:20px 22px; margin-bottom:26px; display:flex; flex-wrap:wrap; align-items:center; gap:14px}
.about-photo-form .apf-text{flex:1; min-width:180px}
.about-photo-form .apf-text strong{font-family:var(--display); font-size:18px; display:block}
.about-photo-form .apf-text span{font-size:13px; color:var(--ink-faint)}
.about-photo-form input[type=file]{flex:1; min-width:160px}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .site-nav,.head-cta{display:none}
  .nav-toggle{display:block}
  body.nav-open .site-nav{display:flex; position:absolute; top:100%; right:14px; flex-direction:column; gap:4px;
    background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:12px; box-shadow:var(--shadow); z-index:70}
  .two-col,.about-grid,.adm-upload-grid{grid-template-columns:1fr; gap:30px}
  .about-frame{transform:none; max-width:360px; margin:0 auto}
  .patch-1,.patch-2,.patch-3,.patch-4,.patch-5{grid-column:span 6}
}
@media (max-width:560px){
  body{font-size:16px}
  .field-row{grid-template-columns:1fr}
  .patch-1,.patch-2,.patch-3,.patch-4,.patch-5{grid-column:span 12; aspect-ratio:4/3}
  .foot-inner{grid-template-columns:1fr; gap:26px}
  .adm-quilts{grid-template-columns:1fr}
}
