/* Apple-inspired public UI tokens + components */
:root{
  --primary:#0066cc;
  --primaryFocus:#0071e3;
  --primaryOnDark:#2997ff;

  --canvas:#ffffff;
  --canvasParchment:#f5f5f7;
  --surfacePearl:#fafafc;

  --tile1:#272729;
  --tile2:#2a2a2c;
  --tile3:#252527;
  --black:#000000;

  --ink:#1d1d1f;
  --muted:#6e6e73;
  --hairline:#e0e0e0;
  --dividerSoft:rgba(0,0,0,.04);

  --radiusSm:8px;
  --radiusLg:18px;
  --radiusPill:9999px;

  --container: 1320px;
  --gutter: 24px;

  --shadowProduct: rgba(0,0,0,.22) 3px 5px 30px 0;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--ink);
  background:var(--canvas);
  font-family: system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  line-height:1.47;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}

/* Global nav (thin black bar) */
.globalNav{
  height:44px;
  background:var(--black);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  position:sticky;
  top:0;
  z-index:50;
}
.globalNavInner{
  width:100%;
  max-width:var(--container);
  padding:0 var(--gutter);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.navBrand{
  font-size:12px;
  letter-spacing:-0.12px;
  color:#fff;
  font-weight:600;
}
.navLinks{
  display:flex;
  gap:18px;
  align-items:center;
  font-size:12px;
  letter-spacing:-0.12px;
  color:rgba(255,255,255,.85);
}
.navLinks a{color:inherit;text-decoration:none}
.navLinks a:hover{color:#fff}
.navRight{
  display:flex;
  gap:12px;
  align-items:center;
}

/* Sub nav frosted */
.subNav{
  position:sticky;
  top:44px;
  z-index:40;
  backdrop-filter:saturate(180%) blur(20px);
  background:rgba(245,245,247,.80);
  border-bottom:1px solid rgba(0,0,0,.08);
}
.subNavInner{
  max-width:var(--container);
  margin:0 auto;
  padding:10px var(--gutter);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.subNavTitle{
  font-size:21px;
  font-weight:600;
  letter-spacing:0.231px;
}
.subNavLinks{
  display:flex;
  align-items:center;
  gap:14px;
  font-size:14px;
  letter-spacing:-0.224px;
  color:rgba(29,29,31,.9);
}

/* Buttons */
.btnPill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:11px 22px;
  border-radius:var(--radiusPill);
  font-size:14px;
  letter-spacing:-0.224px;
  border:1px solid transparent;
  cursor:pointer;
  user-select:none;
  transition:transform .08s ease, filter .12s ease;
  white-space:nowrap;
}
.btnPill:active{transform:scale(.95)}
.btnPrimary{background:var(--primary);color:#fff}
.btnPrimary:focus-visible{outline:2px solid var(--primaryFocus);outline-offset:2px}
.btnGhost{
  background:transparent;
  color:var(--primary);
  border-color:var(--primary);
}
.btnPearl{
  background:var(--surfacePearl);
  color:var(--ink);
  border:1px solid var(--dividerSoft);
}

/* Tiles */
.tile{
  width:100%;
  padding:80px 0;
}
.tileInner{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
  text-align:center;
}
.tileLight{background:var(--canvas);color:var(--ink)}
.tileParchment{background:var(--canvasParchment);color:var(--ink)}
.tileDark{background:var(--tile1);color:#fff}
.tileDark .muted{color:rgba(255,255,255,.75)}
.tileDark a{color:var(--primaryOnDark)}

.heroH{
  font-size:56px;
  font-weight:600;
  letter-spacing:-0.28px;
  line-height:1.07;
  margin:0;
}
.heroLead{
  margin:14px auto 0;
  font-size:28px;
  font-weight:400;
  line-height:1.14;
  max-width:820px;
}
.muted{color:var(--muted)}

/* Utility grid + cards */
.utilityHeader{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
}
.h2{
  font-size:34px;
  font-weight:600;
  letter-spacing:-0.374px;
  margin:0;
}
.p{
  font-size:17px;
  margin:8px 0 0;
  letter-spacing:-0.374px;
}
.searchPill{
  height:44px;
  border-radius:var(--radiusPill);
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
  padding:0 18px;
  font-size:17px;
  letter-spacing:-0.374px;
  width:min(420px, 100%);
  outline:none;
}
.searchPill:focus{border-color:var(--primaryFocus);box-shadow:0 0 0 2px rgba(0,113,227,.18)}

.grid{
  max-width:var(--container);
  margin:24px auto 0;
  padding:0 var(--gutter);
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:20px;
}
@media (max-width:1068px){.grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:834px){.grid{grid-template-columns:repeat(2,1fr)} .heroH{font-size:40px} .heroLead{font-size:21px}}
@media (max-width:640px){.grid{grid-template-columns:1fr} .tile{padding:48px 0} .heroH{font-size:34px}}

.card{
  background:#fff;
  border:1px solid var(--hairline);
  border-radius:var(--radiusLg);
  padding:24px;
  overflow:hidden;
  color:var(--ink);
}
.cardDark{background:transparent;border-color:rgba(255,255,255,.10);color:#fff}
.cardMedia{
  width:100%;
  aspect-ratio:1/1;
  border-radius:var(--radiusSm);
  border:1px solid rgba(0,0,0,.08);
  background:var(--canvasParchment);
  display:grid;
  place-items:center;
  overflow:hidden;
}
.cardMedia img{width:100%;height:100%;object-fit:contain}
.cardTitle{
  margin:16px 0 0;
  font-size:17px;
  font-weight:600;
  letter-spacing:-0.374px;
}
.cardMeta{
  margin-top:6px;
  font-size:14px;
  color:var(--muted);
  letter-spacing:-0.224px;
}
.cardLink{
  margin-top:14px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:14px;
  letter-spacing:-0.224px;
  color:var(--primary);
  text-decoration:none;
}
.cardLink:hover{text-decoration:underline}

/* Footer */
.footer{
  background:var(--canvasParchment);
  padding:64px 0;
  color:var(--ink);
}
.footerInner{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:24px;
}
@media (max-width:834px){.footerInner{grid-template-columns:1fr 1fr;}}
@media (max-width:640px){.footerInner{grid-template-columns:1fr;}}
.footerH{
  font-size:14px;
  font-weight:600;
  letter-spacing:-0.224px;
  margin:0 0 10px;
}
.footerLink{
  display:block;
  font-size:17px;
  line-height:2.41;
  letter-spacing:0;
  color:rgba(29,29,31,.85);
  text-decoration:none;
}
.footerLink:hover{color:var(--ink);text-decoration:underline}
.footerLegal{
  max-width:var(--container);
  margin:32px auto 0;
  padding:16px var(--gutter) 0;
  border-top:1px solid rgba(0,0,0,.08);
  font-size:12px;
  color:rgba(29,29,31,.55);
  letter-spacing:-0.12px;
}

/* —— Simple pages (login, 404, errors): match public chassis —— */
.simplePageMain{
  padding:32px 0 56px;
  background:var(--canvasParchment);
  min-height:calc(100vh - 44px);
}
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
}
.navLogoutForm{display:inline;margin:0}
.navLogoutBtn{
  background:none;border:0;padding:0;
  font:inherit;font-size:12px;letter-spacing:-0.12px;
  color:rgba(255,255,255,.85);cursor:pointer;
}
.navLogoutBtn:hover{color:#fff;text-decoration:underline}

/* —— Admin shell (Apple tokens: light surfaces, one blue accent) —— */
.adminShell{
  min-height:100vh;
  display:grid;
  grid-template-columns:minmax(0,200px) minmax(0,1fr);
  background:var(--canvasParchment);
}
@media (max-width:980px){
  .adminShell{grid-template-columns:1fr}
  .adminSide{
    position:sticky;top:0;z-index:6;
    border-right:0;
    border-bottom:1px solid var(--hairline);
  }
}
.adminSide{
  background:var(--canvas);
  border-right:1px solid var(--hairline);
  padding:10px 10px 12px;
  display:flex;
  flex-direction:column;
  gap:10px;
  min-height:100vh;
  box-sizing:border-box;
}
.adminBrand{
  padding:8px 10px;
  border-radius:var(--radiusSm);
  border:1px solid var(--hairline);
  background:var(--surfacePearl);
  flex:0 0 auto;
}
.adminLogo{font-weight:700;letter-spacing:-0.12px;font-size:13px;line-height:1.2;color:var(--ink)}
.adminSub{margin-top:2px;font-size:11px;line-height:1.3;color:var(--muted)}
/* Pack links tight; do not stretch rows when sidebar is tall (was causing huge gaps) */
.adminNav{
  display:grid;
  gap:0;
  width:100%;
  flex:0 0 auto;
  align-content:start;
}
.adminLink{
  display:block;
  width:100%;
  box-sizing:border-box;
  padding:8px 10px;
  min-height:0;
  border-radius:var(--radiusSm);
  border:1px solid transparent;
  background:transparent;
  color:var(--ink);
  font-size:12px;
  font-weight:600;
  letter-spacing:-0.08px;
  line-height:1.2;
  text-decoration:none;
  text-align:left;
  transition:background .12s ease;
}
.adminLink:hover{background:rgba(0,0,0,.05);text-decoration:none}
.adminLink.active{
  background:rgba(0,102,204,.09);
  border-color:transparent;
  color:var(--ink);
  box-shadow:inset 3px 0 0 var(--primary);
}
.adminSideFooter{
  margin-top:auto;
  padding-top:10px;
  border-top:1px solid var(--hairline);
  flex:0 0 auto;
}
.adminSideFooter .btn{
  width:100%;
  padding:8px 10px;
  font-size:12px;
  font-weight:600;
}
.adminMain{display:grid;grid-template-rows:auto 1fr;min-width:0}
.adminTop{
  position:sticky;top:0;z-index:5;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 20px;
  backdrop-filter:saturate(180%) blur(20px);
  background:rgba(255,255,255,.85);
  border-bottom:1px solid rgba(0,0,0,.08);
}
.adminTitle{font-weight:600;letter-spacing:-0.28px;font-size:21px;color:var(--ink)}
.adminContent{padding:22px 22px 40px}
.adminTopRight .pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:var(--radiusPill);
  border:1px solid var(--hairline);
  background:var(--surfacePearl);
  font-size:12px;color:var(--muted);
}

/* Admin dashboard blocks */
.adminDashTop{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.adminSearchWrap{flex:1;min-width:260px;max-width:520px}
.adminSearch{
  width:100%;height:44px;padding:0 16px;
  border-radius:var(--radiusPill);
  border:1px solid rgba(0,0,0,.08);
  background:#fff;font-size:15px;letter-spacing:-0.224px;
  color:var(--ink);outline:none;
}
.adminSearch:focus{border-color:var(--primaryFocus);box-shadow:0 0 0 2px rgba(0,113,227,.18)}
.adminDashGrid{display:grid;grid-template-columns:1fr 360px;gap:20px;align-items:start}
@media (max-width:1100px){.adminDashGrid{grid-template-columns:1fr}}
.adminDashCard{padding:20px}
.adminDashCardHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.adminDashH{font-weight:600;letter-spacing:-0.28px;font-size:19px}
.uploadBox{
  display:grid;place-items:center;text-align:center;gap:8px;
  padding:28px 16px;border-radius:var(--radiusLg);
  border:1px dashed rgba(0,0,0,.14);
  background:linear-gradient(180deg,var(--surfacePearl),#fff);
  cursor:pointer;user-select:none;
}
.uploadBox:hover{border-color:rgba(0,102,204,.35);background:linear-gradient(180deg,rgba(0,102,204,.06),#fff)}
.uploadIcon{
  width:44px;height:44px;border-radius:var(--radiusSm);
  display:grid;place-items:center;
  background:rgba(0,102,204,.1);border:1px solid rgba(0,102,204,.2);
  font-weight:700;color:var(--primary);
}
.adminDashActions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:14px}
.adminCampaignGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px}
.adminCampaignCard{
  display:block;border-radius:var(--radiusLg);
  border:1px solid var(--hairline);
  background:#fff;overflow:hidden;text-decoration:none;color:inherit;
  box-shadow:0 1px 2px rgba(0,0,0,.04);
}
.adminCampaignCard:hover{border-color:rgba(0,102,204,.25);text-decoration:none;box-shadow:var(--shadowProduct)}
.adminCampaignImg{width:100%;height:140px;object-fit:cover;background:var(--canvasParchment);display:block}
.adminCampaignMeta{padding:12px 12px 14px}
.adminCampaignTitle{font-weight:600;letter-spacing:-0.224px}
.adminFormRow{display:grid;gap:8px;margin-top:10px}
.adminTemplateList{display:grid;gap:10px}
.adminTemplateItem{
  display:flex;align-items:center;gap:10px;padding:12px 14px;
  border-radius:var(--radiusLg);border:1px solid var(--hairline);
  background:var(--surfacePearl);
}
a.adminTemplateItem,a.adminTemplateLink{
  text-decoration:none;color:inherit;
  transition:border-color .12s ease,background .12s ease,box-shadow .12s ease;
}
a.adminTemplateItem:hover,a.adminTemplateLink:hover{
  border-color:rgba(0,102,204,.22);
  background:#fff;
  box-shadow:0 1px 3px rgba(0,0,0,.06);
}
.adminSnapshotList{
  margin:12px 0 0;padding:0 0 0 18px;
  font-size:13px;line-height:1.45;color:var(--ink);
}
.adminSnapshotList li{margin:4px 0}
.adminSnapshotList .muted{display:inline-block;min-width:7.5em;margin-right:6px}
.adminDot{
  width:10px;height:10px;border-radius:var(--radiusPill);
  background:var(--primary);box-shadow:0 0 0 4px rgba(0,102,204,.15);
}

/* Admin / forms: responsive card grid (do not use public catalog `.grid`) */
.gridAdmin{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:20px;
}
.card + .card{margin-top:16px}
.adminContent .card h1,.adminContent .card h2,.adminContent .card h3{margin-top:0}

/* Form controls (admin + login/error pages only — keeps public `.searchPill` untouched) */
.adminContent label,.simplePageMain label{
  display:block;font-weight:600;font-size:13px;letter-spacing:-0.08px;margin:14px 0 8px;color:var(--ink);
}
.adminContent input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
.adminContent textarea,
.adminContent select,
.simplePageMain input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
.simplePageMain textarea,
.simplePageMain select{
  width:100%;padding:11px 14px;border-radius:var(--radiusSm);
  border:1px solid rgba(0,0,0,.12);background:#fff;color:var(--ink);
  font-size:15px;letter-spacing:-0.224px;font-family:inherit;
}
.adminContent input:focus,.adminContent textarea:focus,.adminContent select:focus,
.simplePageMain input:focus,.simplePageMain textarea:focus,.simplePageMain select:focus{
  outline:none;border-color:var(--primaryFocus);box-shadow:0 0 0 3px rgba(0,113,227,.15);
}
.adminContent form .row,.simplePageMain form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:720px){
  .adminContent form .row,.simplePageMain form .row{grid-template-columns:1fr}
}
.inline{display:inline}
.linklike{
  background:none;border:0;padding:0;color:var(--primary);cursor:pointer;font:inherit;
}
.linklike:hover{text-decoration:underline}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:11px 18px;border-radius:var(--radiusPill);
  border:1px solid transparent;font-size:14px;font-weight:500;
  letter-spacing:-0.224px;cursor:pointer;font-family:inherit;
  background:var(--primary);color:#fff;
  transition:filter .12s ease,transform .08s ease;
}
a.btn{box-sizing:border-box}
.btn:hover{filter:brightness(1.05);text-decoration:none}
.btn:active{transform:scale(.98)}
.btn:focus-visible{outline:2px solid var(--primaryFocus);outline-offset:2px}
.btn.secondary{
  background:var(--surfacePearl);color:var(--ink);
  border:1px solid var(--hairline);
}
.btn.secondary:hover{filter:none;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.btn.danger{
  background:rgba(186,26,26,.1);color:#93000a;border:1px solid rgba(186,26,26,.25);
}
.btn.danger:hover{filter:none;background:rgba(186,26,26,.16)}

.notice{
  padding:12px 14px;border-radius:var(--radiusLg);
  border:1px solid var(--hairline);
  background:var(--surfacePearl);
  margin-top:14px;font-size:14px;
}
.notice.error,.card.error{
  border-color:rgba(186,26,26,.35);
  background:rgba(186,26,26,.08);
  color:var(--ink);
}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:var(--radiusPill);
  border:1px solid var(--hairline);
  background:var(--surfacePearl);
  font-size:12px;color:var(--muted);
}
.panelMeta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px;color:var(--muted)}
.sectionLabel{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin:0 0 8px;padding-bottom:10px;border-bottom:1px solid var(--hairline);
}
.sectionLabel h3{margin:0;font-size:12px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted)}
.thumb{
  width:100%;aspect-ratio:1/1;object-fit:cover;
  border-radius:var(--radiusLg);border:1px solid var(--hairline);
  background:var(--canvasParchment);
}

/* Admin: keep moderation thumbnails manageable and consistent */
.adminGalleryThumb{
  height:220px;
  aspect-ratio:auto;
  object-fit:cover;
}
@media (max-width:640px){
  .adminGalleryThumb{height:180px;}
}
code{
  padding:2px 6px;border-radius:6px;
  background:rgba(0,0,0,.05);border:1px solid rgba(0,0,0,.06);
  font-size:12px;
}
h1,h2,h3{letter-spacing:-0.28px}
h1{font-size:28px;line-height:1.15;font-weight:600;margin:0 0 8px}
h2{font-size:21px;font-weight:600}
h3{font-size:17px;font-weight:600}

/* Twibbon-style helpers still used on public campaign page */
.pageSplit{display:grid;grid-template-columns:520px 1fr;gap:20px;align-items:start}
@media (max-width:980px){.pageSplit{grid-template-columns:1fr}}
.frameStage{
  background:#fff;border:1px solid var(--hairline);border-radius:var(--radiusLg);padding:16px;
}
.frameStage img{width:100%;height:auto;display:block;border-radius:var(--radiusSm);border:1px solid rgba(0,0,0,.08);background:var(--canvasParchment)}
.primaryCta{width:100%;border-radius:var(--radiusPill);padding:12px 14px;font-weight:600}
.primaryCta[disabled]{opacity:.55;cursor:not-allowed}
.sidePanel{display:grid;gap:14px}
.panelTitle{margin:0;font-size:22px;font-weight:600;letter-spacing:-0.28px}
.tabs{display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid var(--hairline);margin-bottom:10px}
.tabs a{padding:8px 10px;border-radius:var(--radiusSm);color:var(--ink);text-decoration:none}
.tabs a.active{background:rgba(0,102,204,.1);border:1px solid rgba(0,102,204,.2)}
.galleryStrip{display:flex;gap:10px;overflow:auto;padding:6px 2px}
.galleryStrip::-webkit-scrollbar{height:8px}
.galleryStrip::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12);border-radius:var(--radiusPill)}
.miniThumb{width:72px;height:72px;border-radius:var(--radiusLg);border:1px solid var(--hairline);object-fit:cover;background:var(--canvasParchment);flex:0 0 auto}
.editorLayout{display:grid;grid-template-columns:minmax(320px,620px) 360px;gap:20px;align-items:start}
@media (max-width:980px){.editorLayout{grid-template-columns:1fr}}
.editorCanvas{border-radius:var(--radiusLg);padding:16px;background:#fff;border:1px solid var(--hairline)}
.toolList{display:grid;gap:10px}
.toolRow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:var(--radiusLg);border:1px solid var(--hairline);background:var(--surfacePearl)}
.toolRow strong{font-weight:600}
.rangeRow{display:grid;gap:8px}
.bigDownload{width:100%;padding:12px 14px;border-radius:var(--radiusPill);font-weight:600}
