/* ============================================================
   StoreForge — editorial / atelier theme
   Palette: warm paper, deep ink, vermillion accent
   ============================================================ */
:root{
  --paper:#f4efe7;
  --paper-2:#ebe3d6;
  --ink:#1c1a17;
  --ink-soft:#4a443c;
  --muted:#8a8070;
  --line:#d8cdba;
  --accent:#c8472b;       /* vermillion */
  --accent-deep:#9c3320;
  --gold:#b8893a;
  --card:#fffdf8;
  --shadow:0 18px 40px -24px rgba(40,30,15,.45);
  --r:14px;
  --display:'Fraunces',Georgia,serif;
  --body:'Manrope',-apple-system,sans-serif;
  --mono:'Spline Sans Mono',ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);background:var(--paper);color:var(--ink);
  line-height:1.6;-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(circle at 20% 0%,rgba(200,71,43,.05),transparent 40%),
                   radial-gradient(circle at 90% 10%,rgba(184,137,58,.06),transparent 45%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.muted{color:var(--muted)}
.opt{color:var(--muted);font-weight:400;font-size:.85em}
em{font-style:italic;color:var(--accent)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--body);font-weight:600;font-size:.95rem;cursor:pointer;
  padding:.85em 1.5em;border-radius:50px;border:1.5px solid transparent;
  transition:transform .15s ease,background .2s,color .2s,border-color .2s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-solid{background:var(--ink);color:var(--paper)}
.btn-solid:hover{background:var(--accent)}
.btn-ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-line{background:transparent;border-color:var(--line);color:var(--ink-soft)}
.btn-line:hover{border-color:var(--accent);color:var(--accent)}
.btn-small{padding:.55em 1em;font-size:.85rem}
.btn-tiny{padding:.4em .8em;font-size:.78rem;border-radius:8px;border-color:var(--line)}
.btn-danger{color:var(--accent-deep);border-color:#e3c4bb}
.btn-danger:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.full{width:100%}

/* ---------- header ---------- */
.site-head{display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem clamp(1.2rem,5vw,4rem);max-width:1280px;margin:0 auto}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-size:1.4rem;font-weight:600}
.brand-mark{color:var(--accent);font-size:1.1em}
.brand-mark.big{font-size:2.4rem;display:block;margin-bottom:.3rem}
.site-nav{display:flex;align-items:center;gap:2rem;font-weight:500;font-size:.95rem}
.site-nav a:not(.nav-cta):hover{color:var(--accent)}
.nav-cta{border:1.5px solid var(--ink);border-radius:50px;padding:.5em 1.2em}
.nav-cta:hover{background:var(--ink);color:var(--paper)}

/* ---------- hero ---------- */
.hero{position:relative;max-width:1280px;margin:1rem auto 0;padding:clamp(3rem,8vw,7rem) clamp(1.2rem,5vw,4rem);overflow:hidden}
.hero-grain{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E")}
.hero-inner{position:relative;max-width:760px}
.eyebrow{font-family:var(--mono);text-transform:uppercase;letter-spacing:.22em;font-size:.78rem;color:var(--accent);margin-bottom:1.2rem}
.hero h1{font-family:var(--display);font-weight:600;font-size:clamp(2.8rem,7vw,5.2rem);line-height:1.02;letter-spacing:-.02em;margin-bottom:1.4rem}
.lede{font-size:clamp(1.05rem,2vw,1.25rem);color:var(--ink-soft);max-width:580px;margin-bottom:2rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.hero-stats{display:flex;gap:2.5rem;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:1.8rem}
.hero-stats strong{font-family:var(--display);font-size:2rem;display:block;line-height:1}
.hero-stats span{font-family:var(--mono);font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}

/* ---------- sections ---------- */
.section-title{font-family:var(--display);font-weight:600;font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:-.01em}
.how{max-width:1280px;margin:2rem auto;padding:clamp(2rem,5vw,4rem) clamp(1.2rem,5vw,4rem)}
.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-top:2rem}
.how-grid article{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:2rem;position:relative}
.how-grid .step{font-family:var(--mono);color:var(--accent);font-size:.85rem;letter-spacing:.1em}
.how-grid h3{font-family:var(--display);font-size:1.4rem;margin:.6rem 0 .5rem}
.how-grid p{color:var(--ink-soft);font-size:.95rem}

/* ---------- catalogue ---------- */
.catalogue{max-width:1280px;margin:0 auto;padding:clamp(2rem,5vw,4rem) clamp(1.2rem,5vw,4rem)}
.cat-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}
.cat-tools{display:flex;gap:.6rem}
.cat-tools input{font-family:var(--body);padding:.7em 1em;border:1.5px solid var(--line);border-radius:50px;background:var(--card);min-width:200px}
.cat-tools input:focus{outline:none;border-color:var(--accent)}
.filters{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:2rem}
.chip{font-size:.88rem;font-weight:500;padding:.5em 1.1em;border-radius:50px;border:1.5px solid var(--line);background:var(--card);color:var(--ink-soft);transition:.2s}
.chip:hover{border-color:var(--ink)}
.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.6rem}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--accent)}
.card-feat{border-color:var(--gold)}
.card-img{aspect-ratio:16/10;background:linear-gradient(135deg,#2a2620,#403a30);background-size:cover;background-position:center;position:relative;display:flex;align-items:center;justify-content:center}
.card-img-ph{font-family:var(--display);font-size:3rem;color:rgba(244,239,231,.35)}
.card-img-ph.big{font-size:5rem}
.badge{position:absolute;top:.8rem;left:.8rem;font-family:var(--mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;padding:.35em .7em;border-radius:6px;background:var(--paper);color:var(--ink)}
.badge.feat{background:var(--gold);color:#fff}
.badge.sold{background:var(--accent-deep);color:#fff}
.card-body{padding:1.4rem;display:flex;flex-direction:column;flex:1}
.card-cat{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent)}
.card-body h3{font-family:var(--display);font-size:1.45rem;font-weight:600;margin:.35rem 0 .4rem;line-height:1.1}
.card-body p{color:var(--ink-soft);font-size:.92rem;flex:1}
.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:1.2rem;padding-top:1rem;border-top:1px solid var(--line)}
.price{font-family:var(--display);font-size:1.5rem;font-weight:600;display:flex;flex-direction:column;line-height:1}
.price small{font-family:var(--mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:400;margin-top:.3rem}
.arrow{font-size:1.3rem;color:var(--accent);transition:transform .2s}
.card:hover .arrow{transform:translateX(5px)}
.empty{color:var(--muted);padding:2rem 0}
.empty a{color:var(--accent);text-decoration:underline}

/* ---------- detail ---------- */
.detail{max-width:1180px;margin:0 auto;padding:1.5rem clamp(1.2rem,5vw,4rem) 4rem}
.back{font-family:var(--mono);font-size:.85rem;color:var(--muted);display:inline-block;margin-bottom:1.5rem}
.back:hover{color:var(--accent)}
.detail-grid{display:grid;grid-template-columns:1fr 360px;gap:3rem;align-items:start}
.detail-img{aspect-ratio:16/9;border-radius:var(--r);background:linear-gradient(135deg,#2a2620,#403a30);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;margin-bottom:1.8rem}
.detail h1{font-family:var(--display);font-size:clamp(2rem,4vw,3rem);font-weight:600;letter-spacing:-.01em;margin:.4rem 0}
.detail-tag{font-size:1.15rem;color:var(--ink-soft);margin-bottom:1.5rem}
.detail-desc{color:var(--ink-soft);margin-bottom:1rem}
.sub{font-family:var(--display);font-size:1.3rem;font-weight:600;margin:2rem 0 .8rem}
.feature-list{list-style:none;display:grid;gap:.6rem}
.feature-list li{padding-left:1.6rem;position:relative;color:var(--ink-soft)}
.feature-list li::before{content:'◆';position:absolute;left:0;color:var(--accent);font-size:.7em;top:.35em}
.stack{font-family:var(--mono);font-size:.9rem;color:var(--ink-soft)}
.val-table{width:100%;border-collapse:collapse;margin-top:.5rem;font-size:.95rem}
.val-table td{padding:.7em 0;border-bottom:1px solid var(--line);color:var(--ink-soft)}
.val-table td:nth-child(2){text-align:center;font-family:var(--mono);font-size:.85rem}
.val-table td:last-child{text-align:right;font-weight:600;color:var(--ink)}
.val-total td{border-bottom:none;border-top:2px solid var(--ink);font-family:var(--display);font-size:1.05rem;color:var(--ink);padding-top:.9em}

/* buy card */
.detail-buy{position:sticky;top:2rem}
.buy-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:1.8rem;box-shadow:var(--shadow)}
.buy-price{font-family:var(--display);font-size:2.4rem;font-weight:600;margin:.6rem 0 1.2rem;display:flex;flex-direction:column;line-height:1}
.buy-price small{font-family:var(--mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:400;margin-top:.4rem}
.buy-points{list-style:none;display:grid;gap:.6rem;margin-bottom:1.4rem;font-size:.92rem;color:var(--ink-soft)}
.buy-points li{padding-left:1.5rem;position:relative}
.buy-points li::before{content:'✓';position:absolute;left:0;color:var(--accent);font-weight:700}
.buy-card .btn{margin-top:.7rem}
.sold-note{font-size:.85rem;color:var(--accent-deep);background:#f6e3dd;padding:.8em;border-radius:8px;margin:.7rem 0}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;background:rgba(28,26,23,.6);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:1.2rem;z-index:100}
.modal.open{display:flex}
.modal-card{background:var(--paper);border-radius:var(--r);padding:2.2rem;max-width:460px;width:100%;position:relative;max-height:92vh;overflow:auto;box-shadow:var(--shadow)}
.modal-x{position:absolute;top:1rem;right:1.2rem;background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--muted);line-height:1}
.modal-card h3{font-family:var(--display);font-size:1.7rem;font-weight:600}
.modal-sub{color:var(--accent);font-family:var(--mono);font-size:.85rem;margin-bottom:1.2rem}
.modal-card form{display:grid;gap:1rem}
.modal-card label{display:grid;gap:.35rem;font-size:.85rem;font-weight:600}
.modal-card input,.modal-card textarea,.modal-card select{font-family:var(--body);padding:.75em .9em;border:1.5px solid var(--line);border-radius:10px;background:var(--card);font-size:.95rem;font-weight:400}
.modal-card input:focus,.modal-card textarea:focus,.modal-card select:focus{outline:none;border-color:var(--accent)}
.modal-fine{font-size:.78rem;color:var(--muted);text-align:center}
.thanks{text-align:center;padding:1rem 0}
.thanks .tick{display:inline-flex;width:60px;height:60px;border-radius:50%;background:var(--accent);color:#fff;align-items:center;justify-content:center;font-size:1.8rem;margin-bottom:1rem}
.thanks h3{margin-bottom:.5rem}
.thanks p{color:var(--ink-soft);margin-bottom:1.5rem}

/* ---------- footer ---------- */
.site-foot{border-top:1px solid var(--line);margin-top:3rem}
.foot-inner{max-width:1280px;margin:0 auto;padding:3rem clamp(1.2rem,5vw,4rem);display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.foot-inner strong{font-family:var(--display);font-size:1.3rem}
.foot-inner p{color:var(--muted);font-size:.9rem;margin-top:.3rem}
.foot-meta{text-align:right}
.foot-meta a{color:var(--accent)}
@media(max-width:560px){.foot-meta{text-align:left}}

/* ============================================================
   ADMIN
   ============================================================ */
.admin-body{background:var(--paper-2)}
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1.2rem}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:2.5rem;max-width:380px;width:100%;text-align:center;box-shadow:var(--shadow)}
.login-card h1{font-family:var(--display);font-size:1.8rem}
.login-card label{display:grid;gap:.35rem;text-align:left;font-size:.85rem;font-weight:600;margin:1rem 0}
.login-card input{padding:.75em .9em;border:1.5px solid var(--line);border-radius:10px;font-family:var(--body)}
.login-card input:focus{outline:none;border-color:var(--accent)}
.form-err{background:#f6e3dd;color:var(--accent-deep);padding:.7em;border-radius:8px;font-size:.88rem;margin-top:.8rem}

.admin-head{display:flex;align-items:center;justify-content:space-between;background:var(--ink);color:var(--paper);padding:1rem clamp(1rem,4vw,2.5rem)}
.admin-head .brand{font-size:1.2rem}
.admin-head .brand strong{color:var(--paper)}
.admin-head .muted{color:#8a8070}
.admin-head .btn-ghost{border-color:var(--paper);color:var(--paper)}
.admin-head .btn-ghost:hover{background:var(--paper);color:var(--ink)}
.admin-head .btn:not(.btn-ghost){background:var(--accent);color:#fff;border-color:var(--accent)}
.admin-tabs{display:flex;align-items:center;gap:1.5rem;background:var(--card);padding:.9rem clamp(1rem,4vw,2.5rem);border-bottom:1px solid var(--line);font-weight:600;font-size:.95rem;flex-wrap:wrap}
.admin-tabs a:not(.btn){color:var(--muted);padding-bottom:.2rem;border-bottom:2px solid transparent}
.admin-tabs a.on{color:var(--ink);border-color:var(--accent)}
.admin-tabs .push{margin-left:auto}
.dot{background:var(--accent);color:#fff;border-radius:50px;font-size:.72rem;padding:.1em .55em;margin-left:.2rem}

.admin-main{max-width:1100px;margin:2rem auto;padding:0 clamp(1rem,4vw,2.5rem)}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:2rem}
.panel h2{font-family:var(--display);font-size:1.6rem;font-weight:600;margin-bottom:1.2rem}
.data{width:100%;border-collapse:collapse;font-size:.9rem}
.data th{text-align:left;font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:.6em .8em;border-bottom:2px solid var(--line)}
.data td{padding:.8em .8em;border-bottom:1px solid var(--line);vertical-align:top}
.data tr:hover{background:var(--paper)}
.nowrap{white-space:nowrap}
.msg{max-width:240px;font-size:.85rem;color:var(--ink-soft)}
.tag{display:inline-block;font-family:var(--mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;padding:.25em .6em;border-radius:6px;background:var(--paper-2);color:var(--ink-soft)}
.tag-live{background:#dcebd9;color:#5a6b2f}
.tag-draft{background:#e7ddca;color:var(--muted)}
.tag-sold{background:#f0d9d2;color:var(--accent-deep)}
.tag-whitelabel{background:#dde6e6;color:#3a5a5a}
.tag-custom{background:#f0e4d2;color:var(--gold)}
.inline{display:inline}
.inline select{padding:.4em;border:1.5px solid var(--line);border-radius:8px;font-family:var(--body);font-size:.82rem}

/* admin form */
.form label{display:grid;gap:.35rem;font-size:.85rem;font-weight:600;margin-bottom:1rem}
.form input,.form textarea,.form select{font-family:var(--body);padding:.7em .9em;border:1.5px solid var(--line);border-radius:10px;background:var(--paper);font-size:.95rem;font-weight:400}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--accent);background:#fff}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-row-4{grid-template-columns:repeat(4,1fr)}
.check{flex-direction:row;align-items:center;gap:.6rem;display:flex}
.check input{width:auto}
.calc{background:var(--paper-2);border-radius:10px;padding:1em 1.2em;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.calc strong{font-family:var(--display);font-size:1.5rem}
.calc-fine{font-size:.78rem;color:var(--muted);margin-top:.8rem}
.form-actions{display:flex;gap:1rem;margin-top:1rem}

@media(max-width:860px){
  .detail-grid{grid-template-columns:1fr}
  .detail-buy{position:static}
  .form-row,.form-row-4{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .site-nav a:not(.nav-cta){display:none}
  .form-row,.form-row-4{grid-template-columns:1fr}
  .hero-stats{gap:1.5rem}
}
