:root{
  --bg:#0f0f10; --fg:#f4f4f5; --muted:#a1a1aa; --accent:#9333ea;
  --gap:6px; --rh:260px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--fg);
  font:15px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.g-header{text-align:center;padding:64px 20px 28px}
.g-logo{max-height:60px;max-width:240px;margin:0 auto 14px;display:block;object-fit:contain}
.g-studio{letter-spacing:.18em;text-transform:uppercase;font-size:12px;color:var(--muted)}
.g-title{font-weight:300;font-size:34px;margin:.35em 0 .1em}
.g-sub{color:var(--muted);margin:0}

/* toolbar: favorites + download */
.g-toolbar{display:flex;gap:10px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:22px}
.g-favtoggle{display:inline-flex;align-items:center;gap:7px;padding:10px 16px;border:1px solid #3f3f46;
  border-radius:8px;background:#18181b;color:var(--fg);cursor:pointer;font-size:14px}
.g-favtoggle .ic{color:var(--muted)}
.g-favtoggle[aria-pressed=true]{border-color:var(--accent)}
.g-favtoggle[aria-pressed=true] .ic{color:var(--accent)}
.g-dl button{display:inline-flex;align-items:center;gap:6px}

/* justified gallery (uses each photo's aspect ratio --ar) */
#grid{display:flex;flex-wrap:wrap;gap:var(--gap);padding:var(--gap);align-content:flex-start}
#grid::after{content:"";flex-grow:99999} /* last row keeps natural height */
#grid .g-cell{height:var(--rh);flex-grow:var(--ar,1.5);flex-basis:calc(var(--ar,1.5) * var(--rh));
  aspect-ratio:auto}
.g-cell .g-heart{position:absolute;top:8px;right:8px;display:grid;place-items:center;width:34px;height:34px;
  border:0;border-radius:50%;background:rgba(0,0,0,.4);color:#fff;cursor:pointer;opacity:0;transition:opacity .15s}
.g-cell:hover .g-heart{opacity:1}
.g-cell.is-fav .g-heart{opacity:1}
.g-cell.is-fav .g-heart .ic{color:var(--accent)}
body.show-favs #grid .g-cell:not(.is-fav){display:none}
.g-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:var(--gap);padding:var(--gap)}
.g-cell{position:relative;display:block;aspect-ratio:3/2;overflow:hidden;background:#1a1a1c}
.g-cell img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .35s ease}
.g-cell:hover img{transform:scale(1.04)}
.g-cell-label{position:absolute;left:0;right:0;bottom:0;padding:10px 12px;
  background:linear-gradient(transparent,rgba(0,0,0,.7));font-size:14px}
.g-footer{text-align:center;color:var(--muted);font-size:12px;padding:48px 0 64px}
.g-empty{text-align:center;color:var(--muted);padding:60px 20px}

/* ---- platform landing ---- */
body.lp{background:#0b0b0f;color:#f4f4f5;
  background-image:radial-gradient(900px 500px at 50% -10%, rgba(147,51,234,.18), transparent)}
.lp-nav{display:flex;align-items:center;justify-content:space-between;padding:20px 6vw;max-width:1200px;margin:0 auto}
.lp-brand{font-weight:600}.lp-brand span{color:#a855f7}
.lp-nav nav{display:flex;align-items:center;gap:20px}
.lp-nav a{color:#d4d4d8;text-decoration:none;font-size:15px}
.lp-cta{background:#fff;color:#000;padding:9px 18px;border-radius:999px;font-weight:500}
.lp-cta:hover{background:#e5e5e5}
.lp-hero{text-align:center;padding:90px 6vw 70px;max-width:820px;margin:0 auto}
.lp-hero h1{font-size:clamp(34px,6vw,58px);line-height:1.08;font-weight:600;margin:0 0 22px;letter-spacing:-.02em}
.lp-hero p{font-size:19px;color:#a1a1aa;max-width:600px;margin:0 auto 34px;line-height:1.6}
.lp-hero-cta{display:flex;flex-direction:column;align-items:center;gap:16px}
.lp-cta.lg{padding:14px 30px;font-size:17px}
.lp-link{color:#d4d4d8;text-decoration:none;font-size:15px}
.lp-link:hover{color:#fff}
.lp-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;
  max-width:1080px;margin:30px auto 80px;padding:0 6vw}
.lp-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:28px}
.lp-card h3{display:flex;align-items:center;gap:10px;font-size:18px;margin:0 0 10px;font-weight:600}
.lp-card h3 .ic{color:#a855f7}
.lp-card p{color:#a1a1aa;margin:0;line-height:1.6}
.lp-card em{color:#d4d4d8;font-style:normal;background:rgba(255,255,255,.06);padding:1px 6px;border-radius:5px}
.lp-foot{display:flex;justify-content:space-between;align-items:center;max-width:1080px;margin:0 auto;
  padding:28px 6vw 60px;color:#71717a;font-size:14px;border-top:1px solid rgba(255,255,255,.06)}
.lp-foot a{color:#a855f7;text-decoration:none}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(8,8,9,.96);display:flex;
  align-items:center;justify-content:center;z-index:50}
.lb[hidden]{display:none}
.lb-img{max-width:92vw;max-height:84vh;object-fit:contain}
.lb button{position:absolute;background:none;border:0;color:var(--fg);
  font-size:34px;cursor:pointer;opacity:.8;padding:16px}
.lb button:hover{opacity:1}
.lb-close{top:8px;right:12px}
.lb-prev{left:8px;top:50%;transform:translateY(-50%)}
.lb-next{right:8px;top:50%;transform:translateY(-50%)}
.lb-bar{position:absolute;bottom:18px;left:0;right:0;display:flex;gap:14px;align-items:center;justify-content:center}
.lb-heart{display:grid;place-items:center;width:40px;height:40px;border:1px solid #3f3f46;border-radius:50%;
  background:rgba(255,255,255,.06);color:#fff;cursor:pointer}
.lb-heart.on{border-color:var(--accent)}
.lb-heart.on .ic{color:var(--accent)}
.lb-count{color:var(--muted);font-size:13px;font-variant-numeric:tabular-nums}

@media(max-width:640px){:root{--rh:170px}.g-title{font-size:26px}}

/* gallery "download all" email form */
.g-dl{margin-top:20px;display:inline-flex;gap:8px;justify-content:center;flex-wrap:wrap}
.g-dl input{padding:10px 14px;border:1px solid #3f3f46;border-radius:8px;
  background:#18181b;color:var(--fg);min-width:220px}
.g-dl button{padding:10px 20px;border:0;border-radius:8px;background:#fff;color:#000;
  cursor:pointer;font-weight:500}
.g-dl button:hover{background:#e5e5e5}

/* gallery password gate */
.g-pw{margin-top:18px;display:flex;gap:8px;justify-content:center}
.g-pw input{padding:10px 14px;border:1px solid #3f3f46;border-radius:8px;
  background:#18181b;color:var(--fg)}
.g-pw button{padding:10px 18px;border:0;border-radius:8px;background:#fff;color:#000;cursor:pointer}

/* ---- admin ---- */
body.admin{background:#fafafa;color:#18181b}
.adm-bar{display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;background:#fff;border-bottom:1px solid #e4e4e7}
.adm-brand{font-weight:600;text-decoration:none;color:#18181b}
.adm-brand span{color:#9333ea}
.adm-nav{display:flex;align-items:center;gap:16px;font-size:14px}
.adm-nav a{color:#52525b;text-decoration:none}
.adm-studio{color:#71717a}
.adm-main{max-width:880px;margin:0 auto;padding:32px 24px}
.adm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.adm-head h1{font-size:24px;font-weight:600;margin:0}
.adm-plan{font-size:13px;color:#71717a}
.adm-card{max-width:380px;margin:8vh auto;background:#fff;border:1px solid #e4e4e7;
  border-radius:14px;padding:28px}
.adm-card h1{font-size:20px;margin:0 0 18px}
.adm-form{display:flex;flex-direction:column;gap:14px}
.adm-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.adm-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#52525b}
.adm-form input,.adm-form select{padding:9px 11px;border:1px solid #d4d4d8;
  border-radius:8px;font-size:14px;background:#fff}
.adm-form button{grid-column:1/-1;margin-top:4px;padding:10px;border:0;border-radius:8px;
  background:#18181b;color:#fff;font-size:14px;cursor:pointer}
.adm-form button:hover{background:#000}
.adm-alt{margin-top:16px;font-size:13px;color:#71717a;text-align:center}
.adm-flash{max-width:380px;margin:16px auto -8px;padding:10px 14px;border-radius:8px;font-size:14px}
.adm-err{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}
.adm-ok{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}
.adm-new{background:#fff;border:1px solid #e4e4e7;border-radius:12px;padding:8px 18px;margin-bottom:24px}
.adm-new summary{cursor:pointer;padding:8px 0;font-weight:500;color:#9333ea}
.adm-new .adm-form{padding:12px 0 16px}
.adm-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.adm-row{display:flex;align-items:center;justify-content:space-between;
  background:#fff;border:1px solid #e4e4e7;border-radius:12px;padding:16px 18px}
.adm-meta{font-size:13px;color:#71717a;margin-top:4px}
.adm-meta a{color:#9333ea}
.adm-badge{font-size:11px;text-transform:uppercase;letter-spacing:.05em;
  padding:2px 8px;border-radius:999px;margin-left:8px;vertical-align:middle}
.adm-public{background:#dcfce7;color:#15803d}
.adm-unlisted{background:#e0e7ff;color:#4338ca}
.adm-password{background:#fef9c3;color:#a16207}
.adm-btn{text-decoration:none;font-size:14px;padding:8px 16px;border-radius:8px;
  background:#18181b;color:#fff}
.adm-btn:hover{background:#000}
.adm-empty{color:#71717a;text-align:center;padding:40px 0}
.adm-share{background:#fff;border:1px solid #e4e4e7;border-radius:12px;padding:16px 18px;margin-bottom:20px}
.adm-share label{display:block;font-size:12px;color:#71717a;margin-bottom:6px}
.adm-share input{width:100%;padding:9px 11px;border:1px solid #d4d4d8;border-radius:8px;font-size:13px;color:#3f3f46}
.adm-upload{display:flex;gap:10px;align-items:center;background:#fff;border:1px dashed #d4d4d8;
  border-radius:12px;padding:18px;margin-bottom:24px}
.adm-upload button{padding:9px 16px;border:0;border-radius:8px;background:#18181b;color:#fff;cursor:pointer}
.adm-thumbs{background:transparent}
.adm-thumbs .g-cell{background:#e4e4e7;border-radius:8px}
.ic{display:inline-block;vertical-align:middle}
.adm-nav a:hover{color:var(--accent)}
.adm-brand span{color:var(--accent)}
.adm-actions{display:flex;gap:8px}
.adm-btn.ghost{background:#fff;color:#18181b;border:1px solid #d4d4d8}
.adm-btn.ghost:hover{background:#f4f4f5}
.adm-card-wide{max-width:560px;background:#fff;border:1px solid #e4e4e7;border-radius:14px;padding:24px;margin-bottom:24px}
.adm-card-wide textarea{padding:9px 11px;border:1px solid #d4d4d8;border-radius:8px;font:inherit;font-size:14px;resize:vertical}
.adm-sub{font-size:16px;margin:0 0 4px}
.adm-hint{color:#71717a;font-size:13px;margin:-4px 0 16px}
.adm-color{display:inline-flex;align-items:center;gap:10px}
.adm-color input[type=color]{width:44px;height:32px;border:1px solid #d4d4d8;border-radius:8px;background:#fff;padding:2px}
.adm-logo-prev{max-height:54px;max-width:200px;margin:6px 0;display:block;background:#f4f4f5;border-radius:8px;padding:6px}

/* photo manager */
.adm-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-top:12px}
.adm-photo{position:relative;margin:0;aspect-ratio:1;border-radius:10px;overflow:hidden;
  background:#e4e4e7;cursor:grab;border:2px solid transparent}
.adm-photo.is-cover{border-color:var(--accent)}
.adm-photo img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.adm-photo.dragging{opacity:.4}
.adm-photo figcaption{position:absolute;top:6px;right:6px;display:flex;gap:6px;opacity:0;transition:opacity .15s}
.adm-photo:hover figcaption{opacity:1}
.adm-photo figcaption button{display:grid;place-items:center;width:30px;height:30px;border:0;border-radius:8px;
  background:rgba(0,0,0,.6);color:#fff;cursor:pointer}
.adm-photo figcaption button[data-act=cover]:hover{background:var(--accent)}
.adm-photo figcaption button[data-act=delete]:hover{background:#dc2626}
.adm-photo.is-cover::after{content:"Cover";position:absolute;left:6px;bottom:6px;font-size:11px;
  background:var(--accent);color:#fff;padding:2px 7px;border-radius:6px}

/* danger zone */
.adm-danger{display:flex;align-items:center;justify-content:space-between;gap:16px;max-width:560px;
  background:#fff;border:1px solid #fecaca;border-radius:14px;padding:18px 24px}
.adm-danger p{color:#71717a;font-size:13px;margin:4px 0 0}
.adm-btn-danger{padding:9px 16px;border:0;border-radius:8px;background:#dc2626;color:#fff;cursor:pointer;white-space:nowrap}
.adm-btn-danger:hover{background:#b91c1c}
