/* ============================================================
   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:52px; height:52px; border-radius:50%; object-fit:cover; box-shadow:0 4px 12px -6px rgba(30,42,55,.5)}
.brand-mark{color:var(--navy); display:flex}
.brand-name{font-family:var(--display); font-weight:600; font-size:20px; line-height:1; letter-spacing:.01em; display:block}
.brand-sub{font-size:10.5px; letter-spacing:.28em; text-transform:uppercase; color:var(--ink-faint); display:block; margin-top:3px}
.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:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px}
.adm-quilt{display:flex; gap:14px; align-items:center; background:var(--cream); border:1px solid var(--line); border-radius:12px; padding:12px}
.adm-quilt>img{width:62px; height:78px; 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-actions{display:flex; flex-direction:column; gap:6px}
.adm-quilt-actions form{margin:0}
.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}

/* ---------- "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}
}
