/* The South Shore Digest Local Card — shared styles.
   Brand tokens from clients/ssd/DESIGN.md. Editorial, not SaaS. No em dashes in copy. */
:root{
  --primary:#0D304F;      /* deep navy */
  --secondary:#5D0D07;    /* editorial burgundy */
  --neutral:#F5F2EB;      /* warm cream */
  --warm:#C9A37A;         /* golden-hour accent */
  --warm-deep:#8C6B4A;
  --ink:#26303f;
  --muted:#6f6a60;
  --line:#e4ddcf;
  --white:#ffffff;
  --ok:#1f7a4d;
  --radius:8px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth;}
body{font-family:"Inter",-apple-system,system-ui,sans-serif;color:var(--ink);
  background:var(--neutral);line-height:1.55;font-size:17px;}
h1,h2,h3,h4{font-family:"Montserrat",sans-serif;color:var(--primary);
  letter-spacing:-0.01em;line-height:1.15;}
strong{color:var(--primary);}
a{color:var(--secondary);}
img{max-width:100%;height:auto;display:block;}

.wrap{max-width:760px;margin:0 auto;padding:0 22px;}
.app-wrap{max-width:520px;margin:0 auto;padding:0 18px;}

/* header */
header.brand{background:var(--white);border-bottom:1px solid var(--line);
  padding:16px 0;text-align:center;}
header.brand img{width:230px;max-width:70%;margin:0 auto;}

/* buttons */
.btn{display:inline-block;background:var(--secondary);color:#fff;
  font-family:"Montserrat",sans-serif;font-weight:700;font-size:16px;
  padding:15px 30px;border-radius:var(--radius);border:0;cursor:pointer;
  text-decoration:none;text-align:center;transition:background .15s;}
.btn:hover{background:#8c2018;}  /* lighter shade of the red */
.btn.block{display:block;width:100%;}
.btn.big{font-size:19px;padding:20px 30px;}
.btn.ghost{background:transparent;color:var(--primary);
  border:1.5px solid var(--primary);}
.btn.ghost:hover{background:var(--primary);color:var(--neutral);}
.btn:disabled{opacity:.5;cursor:not-allowed;}

/* hero */
.hero{background:var(--primary);color:#e7ecf3;padding:52px 0 56px;text-align:center;}
.kicker{font-family:"Montserrat",sans-serif;text-transform:uppercase;
  letter-spacing:0.2em;font-size:14px;font-weight:700;color:var(--warm);
  margin-bottom:14px;}
.hero h1{color:var(--white);font-size:38px;font-weight:800;margin-bottom:16px;}
.hero p{font-size:19px;color:#c3cdda;max-width:34ch;margin:0 auto 26px;}
.rule{width:60px;height:3px;background:var(--secondary);border-radius:2px;
  margin:0 auto 20px;}
@media(max-width:560px){.hero h1{font-size:30px;}}

section{padding:40px 0;}
h2{font-size:24px;margin-bottom:14px;}
section h2{color:var(--secondary);}
.lead{font-size:18px;}
ul{margin:0 0 8px 1.1em;}
li{margin-bottom:9px;}
.divider{border:0;border-top:1px solid var(--line);margin:0;}
.note{color:var(--secondary);font-weight:600;}

/* inline email capture (earn the card) */
.signup-row{display:flex;gap:10px;max-width:480px;margin:22px auto 0;align-items:stretch;
  flex-wrap:wrap;}
.signup-row input{flex:1;min-width:200px;padding:14px;border:1px solid #cfc9ba;
  border-radius:var(--radius);font-size:16px;font-family:"Inter",sans-serif;
  color:var(--ink);background:#fff;}
.signup-row input:focus{outline:none;border-color:var(--secondary);}
.signup-row .btn{white-space:nowrap;flex:0 0 auto;}

/* steps */
.steps{display:grid;gap:14px;margin-top:8px;}
.step{display:flex;gap:14px;align-items:flex-start;background:var(--white);
  border:1px solid var(--line);border-radius:12px;padding:18px;}
.step .n{flex:0 0 auto;width:34px;height:34px;border-radius:50%;
  background:var(--primary);color:var(--neutral);font-family:"Montserrat",sans-serif;
  font-weight:800;display:flex;align-items:center;justify-content:center;}
.step h3{font-size:17px;margin-bottom:3px;}
.step p{font-size:15.5px;color:var(--muted);}

/* stats */
.stats{display:flex;gap:12px;flex-wrap:wrap;margin:22px 0 6px;}
.stat{flex:1;min-width:130px;background:var(--white);border:1px solid var(--line);
  border-radius:10px;padding:16px 10px;text-align:center;}
.stat .num{font-family:"Montserrat",sans-serif;font-weight:800;font-size:26px;
  color:var(--secondary);display:block;line-height:1;}
.stat .lbl{font-size:11px;color:var(--muted);text-transform:uppercase;
  letter-spacing:0.05em;margin-top:7px;display:block;}

/* roster chips */
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:6px;}
.chip{background:var(--white);border:1px solid var(--line);border-radius:9999px;
  padding:8px 15px;font-size:14.5px;}
.chip .town{color:var(--muted);font-size:12.5px;}
.empty-roster{color:var(--muted);font-style:italic;}

/* card grid (cardholder app) */
.edition-head{background:var(--primary);color:var(--neutral);padding:24px 18px;
  text-align:center;}
.edition-head .ed-name{font-family:"Montserrat",sans-serif;font-weight:800;
  font-size:22px;color:var(--white);}
.edition-head .ed-meta{font-size:14px;color:#c3cdda;margin-top:6px;}
.progress{font-size:13px;color:var(--warm);margin-top:8px;
  text-transform:uppercase;letter-spacing:0.08em;font-weight:700;}
.deal-grid{display:grid;gap:12px;padding:18px 0 40px;}
.deal{background:var(--white);border:1px solid var(--line);border-radius:12px;
  padding:16px 18px;cursor:pointer;transition:border-color .15s;}
.deal:active{border-color:var(--warm);}
.deal .biz{font-family:"Montserrat",sans-serif;font-weight:700;font-size:17px;
  color:var(--primary);}
.deal .town{font-size:12.5px;color:var(--muted);text-transform:uppercase;
  letter-spacing:0.05em;}
.deal .offer{margin-top:7px;font-size:15.5px;color:var(--ink);}
.deal.redeemed{opacity:.55;cursor:default;background:#efeadf;}
.deal.redeemed .biz{color:var(--muted);}
.redeemed-tag{display:inline-block;margin-top:8px;font-size:13px;font-weight:700;
  color:var(--ok);}

/* deal detail + show-to-staff overlay */
.sheet{position:fixed;inset:0;background:var(--neutral);z-index:50;
  overflow-y:auto;display:none;}
.sheet.open{display:block;}
.sheet-inner{max-width:520px;margin:0 auto;padding:20px 22px 40px;}
.sheet .close{background:none;border:0;color:var(--muted);font-size:15px;
  cursor:pointer;padding:8px 0;font-family:"Inter",sans-serif;}
.sheet h2{color:var(--primary);font-size:26px;margin:6px 0 2px;}
.sheet .town{color:var(--muted);font-size:13px;text-transform:uppercase;
  letter-spacing:0.06em;margin-bottom:18px;}
.offer-box{background:var(--white);border:1px solid var(--line);border-radius:12px;
  padding:20px;margin-bottom:16px;}
.offer-box .title{font-family:"Montserrat",sans-serif;font-weight:800;font-size:20px;
  color:var(--secondary);}
.offer-box .desc{margin-top:8px;font-size:16px;}
.fine{font-size:13px;color:var(--muted);margin-top:14px;}

/* QR */
.qr-screen{text-align:center;padding-top:8px;}
.qr-box{background:var(--white);border:1px solid var(--line);border-radius:16px;
  padding:22px;display:inline-block;margin:14px auto;}
.qr-box img,.qr-box canvas,.qr-box table{width:260px!important;height:260px!important;}
.qr-instr{font-size:16px;color:var(--ink);max-width:30ch;margin:6px auto 0;}

/* staff page */
.staff-shell{min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:26px 20px;text-align:center;}
.staff-card{background:var(--white);border:1px solid var(--line);border-radius:16px;
  padding:28px 24px;max-width:440px;width:100%;}
.staff-card .biz{font-family:"Montserrat",sans-serif;font-weight:800;font-size:24px;
  color:var(--primary);}
.staff-card .offer{font-family:"Montserrat",sans-serif;font-weight:700;font-size:21px;
  color:var(--secondary);margin:14px 0;}
.staff-state{font-size:17px;margin:16px 0;}
.state-ok{color:var(--ok);font-weight:700;font-family:"Montserrat",sans-serif;
  font-size:22px;}
.state-warn{color:var(--secondary);font-weight:700;}
.banner{background:var(--warm);color:#3a2a17;font-size:14px;padding:10px 14px;
  border-radius:8px;margin-top:14px;}

/* forms */
.form-wrap{background:var(--white);border:1px solid var(--line);border-radius:14px;
  padding:30px 26px;margin-top:8px;}
.form-intro{color:var(--muted);margin-bottom:20px;}
label{display:block;font-weight:600;color:var(--primary);font-size:15px;
  margin:18px 0 6px;}
.hint{font-weight:400;color:var(--muted);font-size:13.5px;}
input[type=text],input[type=email],input[type=tel],textarea{
  width:100%;padding:12px 13px;border:1px solid #cfc9ba;border-radius:8px;
  font-family:"Inter",sans-serif;font-size:16px;color:var(--ink);background:#fcfbf7;}
input:focus,textarea:focus{outline:none;border-color:var(--secondary);background:#fff;}
textarea{min-height:84px;resize:vertical;}
.req{color:var(--secondary);}
.fine-form{font-size:13px;color:var(--muted);margin-top:14px;}
.form-msg{margin-top:16px;font-weight:600;}
.form-msg.err{color:var(--secondary);}
.form-msg.ok{color:var(--ok);}

/* loading / message states */
.center-msg{text-align:center;padding:60px 22px;color:var(--muted);}
.spinner{width:34px;height:34px;border:3px solid var(--line);
  border-top-color:var(--primary);border-radius:50%;margin:0 auto 16px;
  animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

footer{background:var(--primary);color:#9fb0c4;padding:26px 0;font-size:14px;
  text-align:center;}
footer a{color:var(--warm);}
footer .tag{font-style:italic;margin-top:8px;color:#7f90a6;}
