:root{
  --gold:#B8935A;--gold-soft:#cdb389;--ink:#2b2622;--cream:#faf6ef;
  --soft:#efe7da;--muted:#6b5f50;--line:#e6ddce;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--ink);font-family:'Inter Tight',system-ui,sans-serif;line-height:1.7;-webkit-font-smoothing:antialiased}
.display{font-family:'Fraunces',serif;font-weight:300}
.display em{font-style:italic;color:var(--gold)}
a{color:inherit}
.center{text-align:center}
.label{letter-spacing:.35em;text-transform:uppercase;font-size:.7rem;color:var(--gold);margin-bottom:1rem;text-align:center}
.lede{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--muted);max-width:600px;margin:1.2rem auto 0;font-style:italic}
.micro{font-size:.78rem;color:#9a8c79;letter-spacing:.05em}
.micro a{color:var(--gold);text-decoration:none}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 2.5rem;background:rgba(250,246,239,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.brand{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:400;text-decoration:none;display:flex;align-items:center;gap:.4rem;color:var(--ink)}
.brand span{color:var(--gold)}
.brand-lockup{gap:.6rem}
.brand-lockup .jfy-mark{width:38px;height:38px;flex-shrink:0;filter:drop-shadow(0 3px 7px rgba(184,147,90,.28));transition:transform .25s}
.brand-lockup:hover .jfy-mark{transform:rotate(-6deg) scale(1.05)}
.brand-word{font-family:'Fraunces',serif;font-weight:500;letter-spacing:.01em}
.nav nav{display:flex;align-items:center;gap:1.8rem}
.nav nav a{text-decoration:none;font-size:.85rem;letter-spacing:.05em;color:var(--ink)}
.btn-pill{position:relative;overflow:hidden;border:1px solid var(--gold);border-radius:999px;padding:.55rem 1.3rem;color:var(--gold)!important;font-weight:500;transition:transform .35s cubic-bezier(.2,.8,.2,1),background .35s,color .35s,box-shadow .35s}
.btn-pill:hover{background:linear-gradient(135deg,#E4C589,#B8935A);border-color:transparent;color:#fff!important;transform:translateY(-2px);box-shadow:0 10px 22px -10px rgba(184,147,90,.7)}
.btn-pill::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-18deg);pointer-events:none;opacity:0}
.btn-pill:hover::after{animation:btnSheen .85s ease forwards}

/* Hero */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:6rem 2rem 4rem}
.eyebrow{letter-spacing:.4em;text-transform:uppercase;font-size:.72rem;color:var(--gold);margin-bottom:2rem}
.hero h1{font-family:'Fraunces',serif;font-weight:200;font-size:clamp(2.6rem,8vw,5.5rem);line-height:1.08}
.hero-cta{display:flex;gap:1rem;justify-content:center;margin-top:2.5rem;flex-wrap:wrap}
.btn-solid{position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(135deg,#3a352e 0%,#26221d 100%);color:#fff;text-decoration:none;padding:.95rem 2.2rem;border-radius:12px;letter-spacing:.12em;text-transform:uppercase;font-size:.75rem;border:1px solid rgba(0,0,0,.2);box-shadow:0 6px 16px -8px rgba(38,34,29,.7);transition:transform .35s cubic-bezier(.2,.8,.2,1),background .35s,box-shadow .35s}
.btn-solid:hover{background:linear-gradient(135deg,#B8935A 0%,#9c7842 100%);transform:translateY(-2px);box-shadow:0 14px 28px -10px rgba(184,147,90,.7)}
.btn-solid::after,.btn-ghost::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-18deg);pointer-events:none;opacity:0}
.btn-solid:hover::after,.btn-ghost:hover::after{animation:btnSheen .85s ease forwards}
.btn-ghost{position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:1px solid var(--gold);border-radius:12px;color:var(--gold);text-decoration:none;padding:.95rem 2.2rem;letter-spacing:.12em;text-transform:uppercase;font-size:.75rem;transition:transform .35s cubic-bezier(.2,.8,.2,1),background .35s,color .35s,box-shadow .35s,border-color .35s}
.btn-ghost:hover{background:linear-gradient(135deg,#E4C589,#B8935A);border-color:transparent;color:#fff;transform:translateY(-2px);box-shadow:0 12px 26px -12px rgba(184,147,90,.7)}
.hero .micro{margin-top:2rem}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;max-width:1000px;margin:0 auto;padding:5rem 2rem;border-top:1px solid var(--line)}
.step span{font-family:'Fraunces',serif;font-size:2rem;color:var(--gold-soft)}
.step h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.3rem;margin:.6rem 0}
.step p{color:var(--muted);font-size:.95rem}

/* Section head */
.section-head{text-align:center;margin-bottom:3rem}
.section-head h2{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(2rem,5vw,3rem)}

/* Catalog */
.catalog{max-width:1100px;margin:0 auto;padding:5rem 2rem}
.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;margin-bottom:3rem}
.theme-card a{text-decoration:none;display:block;background:#fff;border:1px solid var(--line);border-radius:6px;overflow:hidden;transition:.3s}
.theme-card a:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(43,38,34,.1)}
.theme-thumb{height:300px;background:var(--soft) center/cover no-repeat;position:relative}
.theme-tier{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,.9);color:var(--ink);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .7rem;border-radius:999px}
.theme-tier.free{color:var(--gold)}
.theme-meta{padding:1.4rem}
.theme-meta h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.3rem}
.theme-meta p{color:var(--muted);font-size:.9rem;margin-top:.3rem}
.theme-meta .cat{display:inline-block;margin-top:.6rem;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold)}

/* Features */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;max-width:1100px;margin:0 auto;padding:5rem 2rem;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.feature h3{font-size:1.5rem;font-weight:300;margin-bottom:.8rem}
.feature p{color:var(--muted)}

/* Pricing */
.pricing{max-width:1000px;margin:0 auto;padding:5rem 2rem}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin:2rem 0}
.price-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:2.5rem 1.8rem;text-align:center;position:relative}
.price-card.featured{border-color:var(--gold);box-shadow:0 20px 50px rgba(184,147,90,.15)}
.ribbon{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:#fff;font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;padding:.35rem 1rem;border-radius:999px}
.price-card h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.4rem}
.price-card .price{font-family:'Fraunces',serif;font-size:3rem;font-weight:200;margin:.5rem 0 1.5rem;color:var(--gold)}
.price-card ul{list-style:none;text-align:left;margin-bottom:1.8rem}
.price-card li{padding:.5rem 0;border-bottom:1px solid var(--line);font-size:.92rem;color:var(--muted)}

/* Detail */
.detail-hero{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1100px;margin:0 auto;padding:5rem 2rem;align-items:center}
.detail-preview{height:520px;background:var(--soft) center/cover no-repeat;border-radius:8px}
.detail-info h1{font-family:'Fraunces',serif;font-weight:200;font-size:3rem;margin:.5rem 0}
.detail-info .price{font-family:'Fraunces',serif;font-size:2.2rem;color:var(--gold);margin:1.5rem 0}

/* Footer */
.site-footer{text-align:center;padding:4rem 2rem;border-top:1px solid var(--line)}
.site-footer .brand{justify-content:center;margin-bottom:1rem}
.site-footer p{color:var(--muted);font-size:.85rem;margin:.3rem 0}

@media(max-width:760px){
  .steps,.features,.price-grid,.detail-hero{grid-template-columns:1fr}
  .nav{padding:1rem 1.2rem}.nav nav{gap:1rem}.nav nav a:not(.btn-pill){display:none}
}

/* ===== Auth ===== */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:7rem 1.5rem 3rem}
.auth-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:3rem 2.5rem;width:100%;max-width:440px;text-align:center}
.auth-card h1{font-family:'Fraunces',serif;font-weight:300;font-size:2.2rem;margin-bottom:2rem}
.auth-form{text-align:left}
.auth-form label{display:block;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin:1.1rem 0 .4rem}
.auth-form input{width:100%;padding:.85rem;border:1px solid var(--line);background:var(--cream);font-family:inherit;font-size:1rem;border-radius:4px}
.auth-form input:focus{outline:none;border-color:var(--gold)}
.btn-solid.full{width:100%;margin-top:1.8rem;border:none;cursor:pointer;text-align:center}
.auth-msg{min-height:1.2rem;margin-top:1rem;color:#b4452f;font-size:.9rem;text-align:center}
.auth-alt{text-align:center;margin-top:1.5rem;font-size:.9rem;color:var(--muted)}
.auth-alt a{color:var(--gold);text-decoration:none}

/* ===== Dashboard ===== */
.dash{max-width:1100px;margin:0 auto;padding:7rem 2rem 4rem}
.dash-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3rem;flex-wrap:wrap;gap:1.5rem}
.dash-head h1{font-family:'Fraunces',serif;font-weight:300;font-size:2.6rem}
.dash-head .btn-solid{border:none;cursor:pointer}
.serif-note{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.3rem;color:var(--muted)}
.empty{text-align:center;padding:4rem;border:1px dashed var(--line);border-radius:10px}
.inv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.inv-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:1.6rem}
.inv-top{display:flex;align-items:center;gap:.8rem;margin-bottom:.8rem}
.badge{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .6rem;border-radius:999px}
.badge.pub{background:#e8f3ea;color:#3a7d4a}
.badge.draft{background:var(--soft);color:var(--muted)}
.theme-name{font-size:.78rem;color:var(--gold);letter-spacing:.05em}
.inv-card h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.4rem;margin-bottom:.3rem}
.inv-slug{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--muted);margin-bottom:1.2rem}
.inv-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.mini{font-size:.78rem;padding:.45rem .9rem;border:1px solid var(--line);border-radius:4px;text-decoration:none;color:var(--ink);background:#fff;cursor:pointer}
.mini.solid{background:var(--ink);color:#fff;border-color:var(--ink)}
.mini.danger{color:#b4452f;border-color:#e3c3bb}
.mini:hover{border-color:var(--gold)}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(43,38,34,.45);display:none;align-items:center;justify-content:center;z-index:100;padding:1.5rem}
.modal.open{display:flex}
.modal-card{background:#fff;border-radius:10px;padding:2.5rem;width:100%;max-width:420px}
.modal-card h2{font-family:'Fraunces',serif;font-weight:300;font-size:1.8rem;margin-bottom:1.5rem}
.modal-card label{display:block;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin:1rem 0 .4rem}
.modal-card input,.modal-card select{width:100%;padding:.8rem;border:1px solid var(--line);background:var(--cream);font-family:inherit;font-size:1rem;border-radius:4px}
.modal-actions{display:flex;gap:.8rem;justify-content:flex-end;margin-top:1.8rem}
.modal-actions .btn-solid,.modal-actions .btn-ghost{border:none;cursor:pointer;padding:.7rem 1.4rem}
.modal-actions .btn-ghost{border:1px solid var(--gold)}

/* ===================================================================
   Dark mode tokens (toggled via .dark on <html>)
   =================================================================== */
html.dark{--cream:#1a1715;--ink:#f0e9dd;--soft:#2a2520;--line:#34302a;--muted:#a89a86}
html.dark body{background:var(--cream);color:var(--ink)}
html.dark .auth-card2,html.dark .ds-topbar,html.dark .stat-card,html.dark .inv-card,
html.dark .modal-card,html.dark .ds-cta,html.dark .ds-sidebar,html.dark .theme-card a{background:#211d19}

/* ===================================================================
   Auth split layout (WeddingSaas-style, JFY branding)
   =================================================================== */
.auth-split{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.auth-brand{display:flex;align-items:center;justify-content:center;padding:3rem;background:var(--cream);border-right:1px solid var(--line)}
.auth-brand-inner{text-align:center;max-width:360px}
.brand-lg{font-size:2rem;justify-content:center;margin-bottom:1.2rem}
.auth-tagline{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;color:var(--muted)}
.auth-main{display:flex;align-items:center;justify-content:center;padding:2rem;background:#f3eee5}
html.dark .auth-main{background:#161310}
.auth-card2{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:3rem 2.5rem 2.2rem;width:100%;max-width:430px;box-shadow:0 24px 60px rgba(43,38,34,.08)}
.theme-toggle,.ds-toggle{position:absolute;top:1.2rem;right:1.2rem;background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--muted)}
.ds-toggle{position:static}
.auth-h{font-family:'Fraunces',serif;font-weight:400;font-size:1.7rem;text-align:center;margin-bottom:2rem}
.auth-form2 .field{margin-bottom:1rem;position:relative}
.auth-form2 input{width:100%;padding:.9rem 1rem;border:1px solid var(--line);background:var(--cream);font-family:inherit;font-size:1rem;border-radius:8px;color:var(--ink)}
.auth-form2 input:focus{outline:none;border-color:var(--gold)}
.field.pw .pw-toggle{position:absolute;right:.8rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1.1rem;color:var(--muted)}
.field-row{display:flex;align-items:center;justify-content:space-between;margin:.4rem 0 1.2rem;font-size:.85rem}
.checkbox{display:flex;align-items:center;gap:.4rem;color:var(--muted);cursor:pointer}
.muted-link{color:var(--muted);text-decoration:none}
.muted-link:hover{color:var(--gold)}
.btn-enter{width:100%;padding:1rem;background:#4a4d2e;color:#fff;border:none;border-radius:8px;font-size:.95rem;letter-spacing:.05em;cursor:pointer;transition:.25s}
.btn-enter:hover{background:#3a3d24}
.btn-enter.inline{width:auto;padding:.7rem 1.5rem;font-size:.85rem}
.auth-alt2{text-align:center;margin-top:1.3rem;font-size:.9rem;color:var(--muted)}
.auth-alt2 a{color:var(--gold);text-decoration:none;font-weight:500}
.auth-copy{text-align:center;margin-top:1.5rem;font-size:.75rem;color:var(--muted)}
@media(max-width:820px){.auth-split{grid-template-columns:1fr}.auth-brand{display:none}}

/* ===================================================================
   PREMIUM DASHBOARD — glassmorphism + bento grid + collapsible sidebar
   =================================================================== */
:root{
  --glass-bg:rgba(255,255,255,.72);
  --glass-brd:rgba(184,147,90,.18);
  --glass-shadow:0 12px 40px rgba(43,38,34,.08);
  --olive:#3a3d24;--olive-2:#4a4d2e;
  --side-w:252px;--side-w-collapsed:74px;
}
html.dark{
  --glass-bg:rgba(33,29,25,.72);
  --glass-brd:rgba(184,147,90,.22);
  --glass-shadow:0 12px 40px rgba(0,0,0,.45);
}
.glass{background:var(--glass-bg);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);
  border:1px solid var(--glass-brd);box-shadow:var(--glass-shadow)}

/* Shell layout */
.ds-shell{display:grid;grid-template-columns:var(--side-w) 1fr;min-height:100vh;transition:grid-template-columns .28s cubic-bezier(.4,0,.2,1)}
.ds-shell.collapsed{grid-template-columns:var(--side-w-collapsed) 1fr}

/* Sidebar */
.ds-sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;
  background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(250,246,239,.85));
  backdrop-filter:blur(14px);border-right:1px solid var(--line);padding:1.1rem .8rem;overflow:hidden;z-index:30}
html.dark .ds-sidebar{background:linear-gradient(180deg,rgba(28,24,21,.95),rgba(22,19,16,.9))}
.ds-side-head{display:flex;align-items:center;justify-content:space-between;padding:.5rem .5rem 1.3rem;border-bottom:1px solid var(--line);margin-bottom:1rem}
.ds-brand{display:flex;align-items:center;gap:.65rem;text-decoration:none;color:var(--ink);white-space:nowrap;min-width:0}
.jfy-mark{width:38px;height:38px;flex-shrink:0;filter:drop-shadow(0 3px 8px rgba(184,147,90,.28));transition:transform .25s}
.ds-brand:hover .jfy-mark{transform:rotate(-6deg) scale(1.05)}
.ds-brand-text{display:flex;flex-direction:column;line-height:1.05;min-width:0}
.ds-brand-name{font-family:'Fraunces',serif;font-size:1.12rem;font-weight:500;color:var(--ink);letter-spacing:.01em}
.ds-brand-tag{font-family:'Inter Tight',sans-serif;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-top:.18rem;font-weight:500}
.ds-mark{color:var(--gold);font-size:1.3rem}
.ds-collapse{background:var(--soft);border:1px solid var(--line);border-radius:8px;width:28px;height:28px;cursor:pointer;color:var(--muted);font-size:.85rem;flex-shrink:0;transition:.2s;display:flex;align-items:center;justify-content:center}
.ds-collapse:hover{color:var(--gold);border-color:var(--gold)}
.ds-nav{flex:1;overflow-y:auto;overflow-x:hidden}
.ds-group{margin-bottom:1.3rem}
.ds-group-title{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);padding:0 .7rem;margin-bottom:.5rem;white-space:nowrap}
.ds-link{display:flex;align-items:center;gap:.75rem;padding:.62rem .7rem;border-radius:10px;text-decoration:none;color:var(--ink);font-size:.88rem;white-space:nowrap;transition:.2s;position:relative}
.ds-link:hover{background:var(--soft)}
.ds-link.active{background:linear-gradient(90deg,rgba(184,147,90,.16),rgba(184,147,90,.04));color:var(--gold);font-weight:500}
.ds-link.active::before{content:'';position:absolute;left:0;top:18%;bottom:18%;width:3px;border-radius:3px;background:var(--gold)}
.ds-ico{width:22px;display:inline-flex;align-items:center;justify-content:center;color:var(--gold);font-size:.95rem;flex-shrink:0}
.ds-link:hover .ds-ico{transform:scale(1.08)}
.ds-ico i{transition:transform .2s}
.ds-logout{margin-top:.5rem;color:#b4452f}
.ds-logout .ds-ico{color:#b4452f}

/* Collapsed state */
.ds-shell.collapsed .ds-text,.ds-shell.collapsed .ds-group-title,.ds-shell.collapsed .ds-brand-text{display:none}
.ds-shell.collapsed .ds-link{justify-content:center;padding:.62rem}
.ds-shell.collapsed .ds-side-head{justify-content:center}
.ds-shell.collapsed .ds-brand{gap:0;justify-content:center}
.ds-shell.collapsed .jfy-mark{width:34px;height:34px}
.ds-shell.collapsed .ds-link:hover::after{content:attr(data-label);position:absolute;left:calc(100% + 8px);background:var(--olive);color:#fff;padding:.35rem .7rem;border-radius:6px;font-size:.78rem;white-space:nowrap;z-index:60;box-shadow:0 6px 16px rgba(0,0,0,.2)}

/* Column + topbar */
.ds-col{display:flex;flex-direction:column;min-width:0}
.ds-topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:1rem;padding:.8rem 1.6rem;
  background:var(--glass-bg);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.ds-burger{display:none;background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--ink)}
.ds-search-top{flex:1;max-width:480px;display:flex;align-items:center;gap:.55rem;background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:.55rem .95rem;transition:.2s}
.ds-search-top:focus-within{border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,147,90,.1)}
.ds-search-top input{flex:1;border:none;background:none;font-family:inherit;font-size:.9rem;color:var(--ink);outline:none}
.ds-search-ico{color:var(--muted);font-size:.9rem}
.ds-top-right{display:flex;align-items:center;gap:1rem;margin-left:auto}
.ds-toggle{background:var(--soft);border:1px solid var(--line);border-radius:50%;width:38px;height:38px;cursor:pointer;color:var(--muted);font-size:.95rem;display:inline-flex;align-items:center;justify-content:center;transition:.2s}
.ds-toggle:hover{color:var(--gold);border-color:var(--gold)}
.ds-account{display:flex;align-items:center;gap:.7rem}
.ds-acct-meta{text-align:right;line-height:1.25}
.ds-acct-name{display:block;font-size:.85rem;font-weight:600}
.ds-acct-email{display:block;font-size:.72rem;color:var(--muted)}
.ds-avatar{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,var(--gold),#9c7842);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:1.1rem;box-shadow:0 4px 12px rgba(184,147,90,.4)}

/* Main */
.ds-main{padding:2rem 2.4rem 3rem;overflow-x:hidden}
.ds-pagehead{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.8rem;flex-wrap:wrap}
.ds-pagehead h1{font-family:'Fraunces',serif;font-weight:300;font-size:1.9rem;display:flex;align-items:center;gap:.6rem}
.ds-crumb{font-size:.78rem;color:var(--muted);letter-spacing:.05em;margin-top:.3rem}
.ds-hint{color:var(--muted);font-size:.95rem}

/* Command center hero */
.cmd-center{border-radius:16px;padding:1.1rem 1.6rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.6rem;
  background:linear-gradient(120deg,rgba(58,61,36,.92),rgba(74,77,46,.86));color:#f0ecdf;border-color:rgba(184,147,90,.3)}
.cmd-left{display:flex;align-items:center;gap:.7rem;font-size:.82rem;letter-spacing:.08em}
.cmd-dot{width:9px;height:9px;border-radius:50%;background:#7ee0a0;box-shadow:0 0 10px #7ee0a0;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.cmd-title{font-weight:600;color:#fff}
.cmd-badge{font-size:.65rem;background:rgba(126,224,160,.18);color:#9af0b8;padding:.2rem .6rem;border-radius:999px;border:1px solid rgba(126,224,160,.4)}
.cmd-right{display:flex;align-items:center;gap:1.2rem;font-size:.8rem;color:#cfc9b8}
.cmd-meta strong{color:#fff}
.cmd-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;padding:.4rem .9rem;border-radius:8px;cursor:pointer;font-size:.78rem}
.cmd-btn:hover{background:rgba(255,255,255,.2)}

/* Bento grid */
.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.bento-card{border-radius:16px;padding:1.5rem;position:relative;overflow:hidden;transition:.28s}
.bento-card:hover{transform:translateY(-4px);box-shadow:0 22px 50px rgba(43,38,34,.14)}
.bento-lg{grid-column:span 2}
.bento-cta{grid-column:span 2;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;gap:.5rem;
  background:linear-gradient(135deg,rgba(184,147,90,.14),rgba(184,147,90,.03))}
.bento-cta h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.4rem}
.bento-cta p{color:var(--muted);font-size:.9rem;margin-bottom:.5rem}
.bento-top{display:flex;align-items:center;gap:.6rem;margin-bottom:.8rem}
.bento-ico{width:34px;height:34px;border-radius:10px;background:rgba(184,147,90,.14);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.bento-tag{font-size:.66rem;letter-spacing:.14em;color:var(--muted);font-weight:600}
.bento-num{font-family:'Fraunces',serif;font-weight:300;font-size:2.8rem;line-height:1;color:var(--ink)}
.bento-num.sm{font-size:2rem}
.bento-bar{height:5px;background:var(--soft);border-radius:99px;margin:1rem 0 .6rem;overflow:hidden}
.bento-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),#d9b676);border-radius:99px}
.bento-sub{font-size:.8rem;color:var(--muted)}
.bento-sub.gain{color:#3a7d4a}
.bento-pill{display:inline-block;font-size:.95rem;font-weight:600;padding:.35rem .9rem;border-radius:999px;margin:.4rem 0}
.bento-pill.ok{background:rgba(126,224,160,.18);color:#3a7d4a}

/* Invitation toolbar + cards */
.inv-toolbar{display:flex;align-items:center;gap:.8rem;padding:1rem 1.2rem;border-radius:14px;margin-bottom:1.6rem;flex-wrap:wrap}
.inv-search{flex:1;min-width:220px;display:flex;align-items:center;gap:.5rem;background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:.55rem .9rem}
.inv-search.sm{max-width:280px}
.inv-search input{flex:1;border:none;background:none;font-family:inherit;font-size:.9rem;color:var(--ink);outline:none}
.inv-toolbar-spacer{flex:1}
.btn-enter.gold{background:linear-gradient(135deg,var(--gold),#9c7842)}
.btn-enter.gold:hover{filter:brightness(1.06)}
.btn-ghost.sm{padding:.5rem 1rem;font-size:.78rem;border-radius:8px;text-transform:none;letter-spacing:.02em;background:var(--olive);color:#fff;border:none}
.btn-ghost.sm:hover{background:var(--olive-2);color:#fff}

.inv-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.3rem}
.inv-pcard{border-radius:16px;padding:1.3rem;transition:.25s}
.inv-pcard:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(43,38,34,.12)}
.inv-pcard-head{display:flex;align-items:center;gap:.6rem;position:relative}
.inv-pcard-head h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.15rem;flex:1;line-height:1.3}
.pill-status{font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .6rem;border-radius:999px}
.pill-status.active{background:rgba(126,224,160,.18);color:#3a7d4a}
.pill-status.draft{background:var(--soft);color:var(--muted)}
.kebab-wrap{position:relative}
.kebab{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--muted);line-height:1;padding:0 .3rem}
.kebab:hover{color:var(--gold)}
.kebab-menu{display:none;position:absolute;right:0;top:120%;min-width:180px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 16px 40px rgba(43,38,34,.18);padding:.5rem;z-index:50}
html.dark .kebab-menu{background:#211d19}
.kebab-menu.open{display:block;animation:kfade .15s ease}
@keyframes kfade{from{opacity:0;transform:translateY(-4px)}to{opacity:1}}
.km-title{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);padding:.3rem .6rem}
.kebab-menu a{display:flex;align-items:center;gap:.6rem;padding:.55rem .6rem;border-radius:8px;text-decoration:none;color:var(--ink);font-size:.88rem}
.kebab-menu a:hover{background:var(--soft)}
.kebab-menu a.km-danger{color:#b4452f}
.inv-pcard-body{display:flex;align-items:center;gap:1rem;margin:1.1rem 0;padding:.9rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.inv-thumb{width:56px;height:56px;border-radius:12px;background:var(--soft);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}
.inv-info{min-width:0}
.inv-plan{font-weight:600;font-size:.9rem}
.inv-theme{font-size:.8rem;color:var(--gold)}
.inv-stats{font-size:.78rem;color:var(--muted);margin-top:.2rem}
.inv-pcard-actions{display:flex;gap:.5rem}
.act{flex:1;text-align:center;padding:.55rem;border-radius:9px;text-decoration:none;font-size:.8rem;font-weight:500;transition:.2s}
.act.open{background:var(--olive);color:#fff}
.act.open:hover{background:var(--olive-2)}
.act.open.disabled{background:var(--soft);color:var(--muted);cursor:not-allowed}
.act.edit{background:#a8643c;color:#fff}
.act.edit:hover{filter:brightness(1.08)}
.act.share{background:#d9a93a;color:#3a2e10}
.act.share:hover{filter:brightness(1.05)}

/* RSVP dashboard */
.rsvp-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-bottom:1.6rem}
.rsvp-stat{border-radius:14px;padding:1.5rem;text-align:center}
.rs-label{font-size:.82rem;color:var(--muted);margin-bottom:.5rem}
.rs-num{font-family:'Fraunces',serif;font-weight:300;font-size:2.6rem;line-height:1}
.rsvp-stat.ok .rs-num{color:#3a7d4a}
.rsvp-stat.warn .rs-num{color:#b4452f}
.rsvp-stat.doubt .rs-num{color:#c89a2b}
.rsvp-table-wrap{border-radius:16px;padding:1.4rem 1.6rem}
.rsvp-table-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.rsvp-table{width:100%;border-collapse:collapse;font-size:.9rem}
.rsvp-table th{text-align:left;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:.7rem .6rem;border-bottom:1px solid var(--line)}
.rsvp-table td{padding:.85rem .6rem;border-bottom:1px solid var(--line);vertical-align:top}
.rsvp-loading{text-align:center;color:var(--muted);padding:2rem!important}
.msg-cell{max-width:340px;color:var(--muted);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.05rem}
.date-cell{color:var(--muted);font-size:.82rem;white-space:nowrap}
.att{font-size:.7rem;padding:.25rem .6rem;border-radius:999px}
.att.yes{background:rgba(126,224,160,.18);color:#3a7d4a}
.att.no{background:rgba(180,69,47,.14);color:#b4452f}
.att.maybe{background:rgba(200,154,43,.16);color:#a37b18}

/* Modal (glass) */
.modal{position:fixed;inset:0;background:rgba(43,38,34,.5);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:100;padding:1.5rem}
.modal.open{display:flex}
.modal-card{border-radius:16px;padding:2.2rem;width:100%;max-width:440px}
.modal-card h2{font-family:'Fraunces',serif;font-weight:300;font-size:1.7rem;margin-bottom:1.3rem}
.modal-card label{display:block;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:.9rem 0 .4rem}
.modal-card input,.modal-card select{width:100%;padding:.8rem;border:1px solid var(--line);background:var(--cream);font-family:inherit;font-size:1rem;border-radius:8px;color:var(--ink)}
.modal-actions{display:flex;gap:.8rem;justify-content:flex-end;margin-top:1.6rem}
.modal-actions .btn-ghost{border:1px solid var(--gold);color:var(--gold);padding:.7rem 1.4rem;border-radius:8px;cursor:pointer;background:none}
.ds-empty{text-align:center;padding:3.5rem;border-radius:14px;color:var(--muted)}

/* Theme grid reuse in dash */
.ds-main .theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.3rem}
.ds-main .theme-card{border-radius:14px;overflow:hidden}

/* Overlay (mobile drawer) */
.ds-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;z-index:25}
.ds-overlay.show{display:block}

/* Responsive */
@media(max-width:1100px){.bento{grid-template-columns:repeat(2,1fr)}.bento-lg,.bento-cta{grid-column:span 2}.rsvp-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){
  .ds-shell,.ds-shell.collapsed{grid-template-columns:1fr}
  .ds-sidebar{position:fixed;left:0;top:0;width:var(--side-w);transform:translateX(-100%);transition:transform .28s}
  .ds-sidebar.open{transform:translateX(0)}
  .ds-collapse{display:none}
  .ds-burger{display:block}
  .ds-acct-meta{display:none}
  .ds-main{padding:1.3rem}
  .bento,.rsvp-stats,.inv-cards{grid-template-columns:1fr}
  .bento-lg,.bento-cta{grid-column:span 1}
}

/* ===================================================================
   PHASE 3 — SCHEMA-DRIVEN EDITOR (split form + live preview)
   =================================================================== */
.editor-wrap{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1.25rem;align-items:start}
@media(max-width:1100px){.editor-wrap{grid-template-columns:1fr}}

.ed-form-col{display:flex;flex-direction:column;gap:1rem;min-width:0}
.ed-titlebar{display:flex;align-items:flex-end;gap:1rem;padding:1rem 1.1rem;border-radius:16px}
.ed-titlefield{flex:1}
.ed-titlefield label{display:block;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted,#8a8175);margin-bottom:.35rem}
.ed-titlefield input{width:100%;border:none;background:transparent;font-family:'Fraunces',serif;font-size:1.4rem;color:var(--ink,#2b2622);outline:none;border-bottom:1px solid rgba(184,147,90,.25);padding-bottom:.3rem}
.ed-titlefield input:focus{border-bottom-color:var(--gold,#B8935A)}
.ed-themebadge{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold,#B8935A);border:1px solid rgba(184,147,90,.4);padding:.35rem .7rem;border-radius:999px;white-space:nowrap}

.ed-group{border-radius:16px;overflow:hidden;border:1px solid rgba(184,147,90,.16)}
.ed-group summary{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:.95rem 1.1rem;list-style:none;font-family:'Fraunces',serif;font-size:1.05rem;color:var(--ink,#2b2622);user-select:none}
.ed-group summary::-webkit-details-marker{display:none}
.ed-gtitle{font-weight:600}
.ed-chev{transition:transform .25s;color:var(--gold,#B8935A);font-size:1.2rem}
.ed-group[open] .ed-chev{transform:rotate(180deg)}
.ed-group-body{padding:.4rem 1.1rem 1.2rem;display:grid;gap:.9rem}
.ed-field label{display:block;font-size:.74rem;letter-spacing:.06em;color:var(--muted,#8a8175);margin-bottom:.35rem;font-weight:500}
.ed-req{color:#c0563f}
.ed-input{width:100%;padding:.62rem .75rem;border:1px solid rgba(184,147,90,.28);border-radius:10px;background:rgba(255,255,255,.55);font-family:'Inter Tight',system-ui,sans-serif;font-size:.92rem;color:var(--ink,#2b2622);outline:none;transition:border-color .15s,box-shadow .15s}
.ed-input:focus{border-color:var(--gold,#B8935A);box-shadow:0 0 0 3px rgba(184,147,90,.12)}
textarea.ed-input{resize:vertical;min-height:70px}
.ed-help{display:block;margin-top:.3rem;font-size:.72rem;color:var(--muted,#9a9184)}

.ed-image{display:grid;gap:.5rem}
.ed-upwrap{display:flex;align-items:center;gap:.7rem}
.ed-uploadbtn{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.78rem;padding:.4rem .8rem;border:1px dashed rgba(184,147,90,.5);border-radius:8px;color:var(--gold,#B8935A);background:rgba(184,147,90,.06)}
.ed-uploadbtn:hover{background:rgba(184,147,90,.12)}
.ed-upstatus{font-size:.74rem;color:var(--muted,#9a9184)}
.ed-upstatus.ok{color:#3a7d44}.ed-upstatus.err{color:#c0563f}
.ed-thumb img{max-width:120px;max-height:90px;border-radius:8px;border:1px solid rgba(184,147,90,.25);object-fit:cover}

.ed-tip{margin:.2rem .2rem 0}

/* preview column */
.ed-preview-col{position:sticky;top:1rem;display:flex;flex-direction:column;gap:.6rem}
.ed-preview-head{display:flex;align-items:center;gap:.8rem;padding:.6rem .9rem;border-radius:14px 14px 0 0}
.ed-dots{display:flex;gap:.35rem}.ed-dots i{width:9px;height:9px;border-radius:50%;background:rgba(184,147,90,.35);display:block}
.ed-preview-url{flex:1;font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--muted,#9a9184);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ed-device{display:flex;gap:.3rem}
.ed-dev-btn{border:1px solid rgba(184,147,90,.3);background:transparent;color:var(--muted,#9a9184);border-radius:7px;width:30px;height:26px;cursor:pointer;font-size:.85rem}
.ed-dev-btn.active{background:var(--gold,#B8935A);color:#fff;border-color:var(--gold,#B8935A)}
.ed-frame-wrap{display:flex;justify-content:center;background:repeating-linear-gradient(45deg,rgba(184,147,90,.04),rgba(184,147,90,.04) 10px,transparent 10px,transparent 20px);border-radius:0 0 14px 14px;padding:1rem;min-height:560px;border:1px solid rgba(184,147,90,.16);border-top:none}
.ed-frame{border:none;border-radius:12px;background:#fff;box-shadow:0 18px 50px -18px rgba(43,38,34,.4);transition:width .3s}
.ed-frame.phone{width:390px;max-width:100%;height:740px}
.ed-frame.full{width:100%;height:740px}

/* save state pill + header buttons reused from dashboard .ds-btn */
.ed-savestate{font-size:.74rem;color:#3a7d44;display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .6rem;border-radius:999px;background:rgba(58,125,68,.1)}
.ed-savestate.saving{color:var(--gold,#B8935A);background:rgba(184,147,90,.12)}
.ed-savestate.err{color:#c0563f;background:rgba(192,86,63,.12)}

html.dark .ed-input{background:rgba(255,255,255,.06);color:#ece6da;border-color:rgba(184,147,90,.3)}
html.dark .ed-titlefield input{color:#ece6da}
html.dark .ed-group summary,html.dark .ed-gtitle{color:#ece6da}

/* ===================================================================
   PHASE 4 — SHARE & INVITE CONSOLE
   =================================================================== */
.share-wrap{display:flex;flex-direction:column;gap:1rem}
.share-warn{display:flex;align-items:center;gap:.6rem;padding:.85rem 1.1rem;border-radius:12px;color:#9a6a1a;font-size:.88rem;border:1px solid rgba(184,147,90,.3)}
.share-warn a{color:var(--gold,#B8935A);text-decoration:underline}
.share-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;align-items:start}
@media(max-width:900px){.share-grid{grid-template-columns:1fr}}
.share-card{padding:1.4rem 1.5rem;border-radius:18px}
.share-card h3{font-family:'Fraunces',serif;font-size:1.25rem;margin:0 0 .25rem;color:var(--ink,#2b2622)}
.share-sub{font-size:.84rem;color:var(--muted,#9a9184);margin:0 0 1.1rem}
.share-label{display:block;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted,#8a8175);margin:.9rem 0 .35rem}
.share-input{width:100%;padding:.65rem .8rem;border:1px solid rgba(184,147,90,.28);border-radius:10px;background:rgba(255,255,255,.6);font-family:'Inter Tight',sans-serif;font-size:.9rem;color:var(--ink,#2b2622);outline:none}
.share-input:focus{border-color:var(--gold,#B8935A);box-shadow:0 0 0 3px rgba(184,147,90,.12)}
.share-input.mono{font-family:'JetBrains Mono',monospace;font-size:.8rem}
.share-textarea{resize:vertical;line-height:1.55}
.share-linkrow{display:flex;gap:.5rem}
.share-linkrow .share-input{flex:1}
.share-qr{display:flex;justify-content:center;margin:1.2rem 0 .8rem;padding:1rem;background:#fff;border-radius:14px;border:1px solid rgba(184,147,90,.18)}
.share-tabs{display:inline-flex;gap:.3rem;background:rgba(184,147,90,.08);padding:.25rem;border-radius:999px;margin-bottom:1rem}
.share-tab{border:none;background:transparent;padding:.4rem .9rem;border-radius:999px;font-size:.82rem;cursor:pointer;color:var(--muted,#8a8175)}
.share-tab.active{background:var(--gold,#B8935A);color:#fff}
.share-channels{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}
html.dark .share-input{background:rgba(255,255,255,.06);color:#ece6da}
html.dark .share-card h3{color:#ece6da}

/* ===================================================================
   PHASE 5 — BILLING & PRICING
   =================================================================== */
.bl-wrap{display:flex;flex-direction:column;gap:1.25rem}
.bl-current{display:flex;justify-content:space-between;align-items:center;padding:1.4rem 1.6rem;border-radius:18px}
.bl-curlabel{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted,#8a8175)}
.bl-curname{font-family:'Fraunces',serif;font-size:1.8rem;margin:.2rem 0 .1rem;color:var(--ink,#2b2622)}
.bl-curmeta{font-size:.84rem;color:var(--muted,#9a9184);margin:0}
.bl-curbadge{font-size:.78rem;padding:.45rem .9rem;border-radius:999px;border:1px solid rgba(184,147,90,.35);color:var(--muted,#8a8175)}
.bl-curbadge.on{background:rgba(58,125,68,.12);color:#3a7d44;border-color:rgba(58,125,68,.3)}

.bl-pricehead{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem}
.bl-pricehead h3{font-family:'Fraunces',serif;font-size:1.3rem;margin:0;color:var(--ink,#2b2622)}
.bl-billtoggle{display:inline-flex;gap:.3rem;background:rgba(184,147,90,.08);padding:.25rem;border-radius:999px}
.bl-billtoggle button{border:none;background:transparent;padding:.45rem 1rem;border-radius:999px;font-size:.82rem;cursor:pointer;color:var(--muted,#8a8175)}
.bl-billtoggle button.active{background:var(--gold,#B8935A);color:#fff}

.bl-plans{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.bl-plan{position:relative;padding:1.5rem 1.4rem;border-radius:18px;display:flex;flex-direction:column;gap:.8rem}
.bl-plan.popular{border:1.5px solid var(--gold,#B8935A);box-shadow:0 18px 50px -22px rgba(184,147,90,.5)}
.bl-pop{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--gold,#B8935A);color:#fff;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .7rem;border-radius:999px}
.bl-plan h4{font-family:'Fraunces',serif;font-size:1.3rem;margin:0;color:var(--ink,#2b2622)}
.bl-price{font-family:'Fraunces',serif;font-size:2rem;color:var(--gold,#B8935A)}
.bl-price span{font-size:.85rem;color:var(--muted,#9a9184);font-family:'Inter Tight',sans-serif}
.bl-feats{list-style:none;padding:0;margin:.2rem 0;display:flex;flex-direction:column;gap:.5rem;flex:1}
.bl-feats li{font-size:.85rem;color:var(--ink,#3a342d);padding-left:1.3rem;position:relative}
.bl-feats li::before{content:'✓';position:absolute;left:0;color:var(--gold,#B8935A);font-weight:600}

.bl-coupon{display:flex;align-items:center;gap:.8rem;padding:1rem 1.3rem;border-radius:14px;flex-wrap:wrap}
.bl-coupon span:first-child{font-size:.85rem;color:var(--muted,#8a8175)}
.bl-coupon input{padding:.55rem .8rem;border:1px solid rgba(184,147,90,.28);border-radius:9px;background:rgba(255,255,255,.6);font-family:'JetBrains Mono',monospace;font-size:.82rem;text-transform:uppercase}
.bl-couponmsg{font-size:.8rem;color:#3a7d44}

.bl-orders{padding:1.4rem 1.5rem;border-radius:18px}
.bl-orders h3{font-family:'Fraunces',serif;font-size:1.25rem;margin:0 0 1rem;color:var(--ink,#2b2622)}
.bl-empty{text-align:center;color:var(--muted,#9a9184);padding:1.5rem!important}
.bl-status,.bl-channel{font-size:.72rem;padding:.2rem .6rem;border-radius:999px;text-transform:capitalize}
.bl-status.paid{background:rgba(58,125,68,.12);color:#3a7d44}
.bl-status.pending{background:rgba(184,147,90,.12);color:#9a6a1a}
.bl-status.failed,.bl-status.refunded{background:rgba(192,86,63,.12);color:#c0563f}
.bl-channel.web{background:rgba(58,90,125,.12);color:#3a5a7d}
.bl-channel.etsy{background:rgba(214,109,46,.14);color:#c25718}
html.dark .bl-curname,html.dark .bl-pricehead h3,html.dark .bl-plan h4,html.dark .bl-orders h3{color:#ece6da}
html.dark .bl-feats li{color:#cfc7b9}
html.dark .bl-coupon input{background:rgba(255,255,255,.06);color:#ece6da}

/* ===================================================================
   PHASE 6 — ETSY REDEEM PAGE
   =================================================================== */
.redeem-main{min-height:calc(100vh - 70px);display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:radial-gradient(1200px 500px at 50% -10%,rgba(184,147,90,.12),transparent)}
.redeem-card{max-width:480px;width:100%;padding:2.4rem 2.2rem;border-radius:22px;text-align:center}
.redeem-badge{display:inline-block;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:#c25718;background:rgba(214,109,46,.12);padding:.3rem .8rem;border-radius:999px;margin-bottom:1rem}
.redeem-card .display{font-size:2rem;margin:.2rem 0 .6rem}
.redeem-label{display:block;text-align:left;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted,#8a8175);margin:1.1rem 0 .35rem}
.redeem-input{width:100%;padding:.8rem .9rem;border:1px solid rgba(184,147,90,.3);border-radius:11px;background:rgba(255,255,255,.65);font-family:'JetBrains Mono',monospace;font-size:1rem;letter-spacing:.04em;text-align:center;outline:none;text-transform:uppercase}
.redeem-input:focus{border-color:var(--gold,#B8935A);box-shadow:0 0 0 3px rgba(184,147,90,.12)}
.redeem-check{min-height:1.2rem;font-size:.82rem;margin-top:.4rem;text-align:left}
.redeem-check.ok{color:#3a7d44}.redeem-check.err{color:#c0563f}
.redeem-submit{width:100%;margin-top:1.4rem}
.redeem-msg{min-height:1.3rem;margin:.9rem 0 0;font-size:.88rem}
.redeem-msg.ok{color:#3a7d44}.redeem-msg.err{color:#c0563f}
.redeem-foot{margin-top:1.2rem;font-size:.8rem;color:var(--muted,#9a9184)}
html.dark .redeem-input{background:rgba(255,255,255,.06);color:#ece6da}

/* ===== Fase 7: Affiliate / Reseller ===== */
.aff-wrap{display:flex;flex-direction:column;gap:1.4rem}
.aff-stats{margin-bottom:.2rem}
.aff-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:1.4rem;align-items:start}
@media(max-width:920px){.aff-grid{grid-template-columns:1fr}}
.aff-card{padding:1.5rem 1.6rem;border-radius:18px}
.aff-card h3{font-family:'Fraunces',serif;font-size:1.15rem;margin:0 0 .3rem;color:var(--ink,#2c2722)}
.aff-card .aff-sub{font-size:.84rem;color:var(--muted,#9a9184);margin:0 0 1.1rem}
.aff-codepill{display:inline-flex;align-items:center;gap:.6rem;background:linear-gradient(135deg,#B8935A,#a07d48);color:#fff;
  font-family:'JetBrains Mono',monospace;font-weight:600;letter-spacing:.06em;padding:.55rem 1rem;border-radius:12px;font-size:1.05rem}
.aff-codepill button{background:rgba(255,255,255,.2);border:0;color:#fff;border-radius:8px;padding:.3rem .55rem;cursor:pointer;font-size:.78rem}
.aff-codepill button:hover{background:rgba(255,255,255,.32)}
.aff-channels{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}
.aff-channels a,.aff-channels button{display:inline-flex;align-items:center;gap:.45rem;border:1px solid var(--line,#e7ded0);
  background:#fff;border-radius:11px;padding:.55rem .9rem;font-size:.83rem;font-weight:600;color:var(--ink,#2c2722);cursor:pointer;text-decoration:none;transition:.15s}
.aff-channels a:hover,.aff-channels button:hover{border-color:#B8935A;color:#a07d48;transform:translateY(-1px)}
.aff-channels .wa{background:#25D366;color:#fff;border-color:#25D366}
.aff-channels .wa:hover{background:#1eb858;color:#fff}
#aff-qr{margin-top:1rem;display:flex;justify-content:center}
#aff-qr img{border-radius:14px;border:1px solid var(--line,#e7ded0);padding:.5rem;background:#fff}
.aff-brandgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.aff-brandfull{grid-column:1 / -1}
.aff-toggle{display:flex;align-items:center;gap:.7rem;margin:.4rem 0 1rem}
.aff-switch{position:relative;width:46px;height:26px;flex:none}
.aff-switch input{opacity:0;width:0;height:0}
.aff-switch label{position:absolute;inset:0;background:#d8cfc0;border-radius:30px;cursor:pointer;transition:.2s}
.aff-switch label:before{content:'';position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.aff-switch input:checked + label{background:#B8935A}
.aff-switch input:checked + label:before{transform:translateX(20px)}
.bl-status{display:inline-block;padding:.2rem .6rem;border-radius:30px;font-size:.72rem;font-weight:700;text-transform:capitalize}
.bl-status.pending{background:#fff4e0;color:#b07d1a}
.bl-status.approved{background:#e3f2ff;color:#1f6fb0}
.bl-status.paid{background:#e6f6ea;color:#3a7d44}
.bl-empty{text-align:center;color:var(--muted,#9a9184);padding:2.2rem 1rem;font-size:.9rem}
.aff-payout{display:flex;gap:.6rem;margin-top:.9rem;flex-wrap:wrap}
.aff-payout input{flex:1;min-width:180px}
html.dark .aff-channels a,html.dark .aff-channels button{background:rgba(255,255,255,.06);color:#ece6da}
html.dark #aff-qr img{background:#fff}

/* Reseller branding footer (injected into theme templates) */
.jfy-reseller-foot{margin-top:0;padding:2.2rem 1.5rem 2.6rem;text-align:center;background:rgba(0,0,0,.03);
  font-family:'Inter Tight',system-ui,sans-serif}
.jfy-reseller-foot .rs-logo{max-height:48px;margin:0 auto .6rem;display:block}
.jfy-reseller-foot .rs-name{font-family:'Fraunces',serif;font-size:1.05rem;font-weight:600;color:#2c2722;margin:0 0 .25rem}
.jfy-reseller-foot .rs-desc{font-size:.82rem;color:#7d756a;margin:0 0 .7rem;max-width:340px;margin-left:auto;margin-right:auto}
.jfy-reseller-foot a{color:#a07d48;text-decoration:none;font-weight:600;font-size:.85rem;margin:0 .5rem}
.jfy-reseller-foot a:hover{text-decoration:underline}

/* ===== Fase 8: Admin panel ===== */
.adm-stats{margin-bottom:1.2rem}
.adm-card{padding:1.4rem 1.5rem;border-radius:18px;margin-bottom:1.3rem}
.adm-card h3{font-family:'Fraunces',serif;font-size:1.12rem;margin:0 0 1rem;color:var(--ink,#2c2722)}
.adm-toolbar{display:flex;gap:.7rem;margin-bottom:1.1rem;flex-wrap:wrap}
.adm-input{border:1px solid var(--line,#e7ded0);border-radius:11px;padding:.6rem .9rem;font-size:.88rem;
  background:#fff;color:var(--ink,#2c2722);min-width:200px;font-family:inherit}
.adm-input:focus{outline:none;border-color:#B8935A;box-shadow:0 0 0 3px rgba(184,147,90,.12)}
.adm-sub{font-size:.78rem;color:var(--muted,#9a9184)}
.adm-chip{display:inline-block;background:#f4ece0;color:#8a6d3f;border-radius:30px;padding:.15rem .6rem;font-size:.72rem;font-weight:700;text-transform:capitalize}
.adm-mini{border:1px solid var(--line,#e7ded0);border-radius:8px;padding:.35rem .5rem;font-size:.8rem;background:#fff;color:var(--ink,#2c2722);font-family:inherit}
.adm-mini:focus{outline:none;border-color:#B8935A}
.adm-mini-btn{position:relative;overflow:hidden;border:1px solid var(--line,#e7ded0);background:#fff;border-radius:8px;padding:.4rem .8rem;font-size:.78rem;
  font-weight:600;cursor:pointer;color:var(--ink,#2c2722);transition:transform .25s cubic-bezier(.2,.8,.2,1),border-color .25s,color .25s,box-shadow .25s}
.adm-mini-btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(184,147,90,.3),transparent);transform:skewX(-18deg);pointer-events:none;opacity:0}
.adm-mini-btn:hover::after{animation:btnSheen .85s ease forwards}
.adm-mini-btn:hover{border-color:#B8935A;color:#a07d48;transform:translateY(-2px);box-shadow:0 8px 18px -10px rgba(184,147,90,.45)}
.adm-actions{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}
.adm-genrow{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center}
.adm-genout{margin-top:.4rem;line-height:2.1}
.adm-codechip{display:inline-block;background:#2c2722;color:#f4ece0;font-family:'JetBrains Mono',monospace;
  font-size:.78rem;padding:.25rem .55rem;border-radius:7px;cursor:pointer;margin:.1rem}
.adm-codechip:hover{background:#B8935A;color:#fff}
.a-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%,80px);background:#2c2722;color:#fff;
  padding:.8rem 1.4rem;border-radius:12px;font-size:.88rem;font-weight:600;z-index:9999;opacity:0;
  transition:.3s cubic-bezier(.2,.8,.2,1);box-shadow:0 8px 30px rgba(0,0,0,.25)}
.a-toast.show{transform:translate(-50%,0);opacity:1}
.a-toast.err{background:#c0563f}
.a-toast.ok{background:#3a7d44}
html.dark .adm-input,html.dark .adm-mini,html.dark .adm-mini-btn{background:rgba(255,255,255,.06);color:#ece6da;border-color:rgba(255,255,255,.12)}
html.dark .adm-chip{background:rgba(184,147,90,.18);color:#d9b87f}

/* ===== Fase 9: Legal pages, settings, cookie consent ===== */
.legal-top{display:flex;justify-content:space-between;align-items:center;padding:1.2rem 2rem;border-bottom:1px solid #ece4d6;background:#faf6ef}
.legal-top .brand{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:600;color:#2c2722;text-decoration:none}
.legal-top nav a{margin-left:1.3rem;color:#7d756a;text-decoration:none;font-size:.9rem;font-weight:600}
.legal-top nav a:hover{color:#a07d48}
.legal-wrap{max-width:760px;margin:0 auto;padding:3rem 1.5rem 4rem}
.legal-wrap h1{font-family:'Fraunces',serif;font-size:2.2rem;color:#2c2722;margin:0 0 .3rem}
.legal-updated{color:#9a9184;font-size:.85rem;margin:0 0 2.2rem}
.legal-sec{margin-bottom:1.8rem}
.legal-sec h2{font-family:'Fraunces',serif;font-size:1.25rem;color:#2c2722;margin:0 0 .6rem}
.legal-sec p,.legal-sec li{color:#5b5249;line-height:1.7;font-size:.95rem}
.legal-sec ul{padding-left:1.2rem}
.legal-sec a{color:#a07d48;font-weight:600}
.foot-links{margin:.4rem 0}
.foot-links a{color:inherit;text-decoration:none;border-bottom:1px solid transparent}
.foot-links a:hover{border-bottom-color:currentColor}
.cookie-bar{position:fixed;bottom:0;left:0;right:0;background:#2c2722;color:#f4ece0;display:flex;
  align-items:center;justify-content:center;gap:1.2rem;padding:.9rem 1.4rem;font-size:.86rem;z-index:9998;flex-wrap:wrap}
.cookie-bar a{color:#d9b87f;font-weight:600}
.cookie-bar button{background:linear-gradient(135deg,#E4C589,#B8935A);color:#fff;border:0;border-radius:9px;padding:.55rem 1.3rem;font-weight:600;cursor:pointer;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s,filter .3s}
.cookie-bar button:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 10px 22px -10px rgba(184,147,90,.7)}
.set-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;align-items:start}
@media(max-width:820px){.set-grid{grid-template-columns:1fr}}
.set-label{display:block;font-size:.82rem;font-weight:600;color:var(--ink,#2c2722);margin:.9rem 0 .4rem}
.set-danger{border:1px solid #e8c4ba}
.set-danger h3{color:#c0563f}
/* dashboard / admin action buttons — premium polish */
.ds-btn{
  position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  font-family:'Inter Tight',system-ui,sans-serif;font-weight:600;font-size:.82rem;letter-spacing:.02em;
  text-decoration:none;line-height:1;padding:.6rem 1.2rem;border-radius:10px;cursor:pointer;
  border:1px solid var(--line,#e7ded0);background:#fff;color:var(--ink,#2c2722);
  transition:transform .3s cubic-bezier(.2,.8,.2,1),background .3s,color .3s,box-shadow .3s,border-color .3s;
}
.ds-btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-18deg);pointer-events:none;opacity:0}
.ds-btn:hover::after{animation:btnSheen .85s ease forwards}
.ds-btn:active{transform:translateY(1px) scale(.99)}
.ds-btn.ghost{background:#fff;color:var(--ink,#2c2722);border-color:var(--line,#e7ded0)}
.ds-btn.ghost:hover{border-color:#B8935A;color:#a07d48;transform:translateY(-2px);box-shadow:0 10px 22px -12px rgba(184,147,90,.5)}
.ds-btn.primary{background:linear-gradient(135deg,#E4C589 0%,#B8935A 48%,#9c7842 100%);color:#fff;border-color:rgba(140,108,60,.5);box-shadow:0 6px 16px -8px rgba(184,147,90,.6)}
.ds-btn.primary:hover{transform:translateY(-2px);box-shadow:0 14px 28px -10px rgba(184,147,90,.8)}
.ds-btn.danger{background:#c0563f;color:#fff;border-color:#c0563f}
.ds-btn.danger:hover{background:#a8462f;transform:translateY(-2px);box-shadow:0 12px 24px -12px rgba(192,86,63,.6)}
html.dark .ds-btn.ghost{background:rgba(255,255,255,.06);color:#ece6da;border-color:rgba(255,255,255,.12)}
html.dark .ds-btn.ghost:hover{border-color:#B8935A;color:#e4c589}

/* ============================================================
   PREMIUM BUTTON SYSTEM  (creative, unified)
   Use class="btn" + a modifier: .btn-gold .btn-ink .btn-outline .btn-soft .btn-ghost-lux
   Sizes: .btn-sm .btn-lg .btn-block   Extras: .btn-icon .btn-shimmer
   ============================================================ */
.btn{
  --btn-radius:12px;
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:'Inter Tight',system-ui,sans-serif;font-weight:500;font-size:.82rem;
  letter-spacing:.06em;text-transform:uppercase;text-decoration:none;line-height:1;
  padding:.85rem 1.6rem;border:1px solid transparent;border-radius:var(--btn-radius);
  cursor:pointer;overflow:hidden;white-space:nowrap;user-select:none;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,background .35s,color .35s,border-color .35s;
  will-change:transform;
}
.btn i{font-size:.92em;line-height:1}
.btn:active{transform:translateY(1px) scale(.99)}
.btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.btn[disabled],.btn.is-disabled{opacity:.5;pointer-events:none;cursor:not-allowed}

/* shimmer sweep — shared light streak across all premium buttons */
.btn::after{
  content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-18deg);transition:none;pointer-events:none;opacity:0;
}
.btn:hover::after{animation:btnSheen .85s ease forwards}
@keyframes btnSheen{0%{left:-120%;opacity:1}100%{left:140%;opacity:1}}

/* --- GOLD (primary luxury) --- */
.btn-gold{
  background:linear-gradient(135deg,#E4C589 0%,#B8935A 48%,#9c7842 100%);
  color:#fff;border-color:rgba(140,108,60,.5);
  box-shadow:0 6px 18px -8px rgba(184,147,90,.65),inset 0 1px 0 rgba(255,255,255,.35);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(184,147,90,.8),inset 0 1px 0 rgba(255,255,255,.45)}

/* --- INK (dark, editorial) --- */
.btn-ink{
  background:linear-gradient(135deg,#3a352e 0%,#26221d 100%);
  color:#fff;border-color:rgba(0,0,0,.2);
  box-shadow:0 6px 16px -8px rgba(38,34,29,.7);
}
.btn-ink:hover{transform:translateY(-2px);background:linear-gradient(135deg,#B8935A 0%,#9c7842 100%);box-shadow:0 14px 28px -10px rgba(184,147,90,.7)}

/* --- OUTLINE (gold border, fills on hover) --- */
.btn-outline{
  background:transparent;color:var(--gold);border-color:var(--gold);
}
.btn-outline:hover{transform:translateY(-2px);background:linear-gradient(135deg,#E4C589,#B8935A);color:#fff;border-color:transparent;box-shadow:0 12px 26px -12px rgba(184,147,90,.7)}

/* --- SOFT (cream tint, subtle) --- */
.btn-soft{
  background:rgba(184,147,90,.1);color:var(--gold);border-color:rgba(184,147,90,.28);
}
.btn-soft:hover{transform:translateY(-2px);background:rgba(184,147,90,.18);border-color:rgba(184,147,90,.5)}

/* --- GHOST LUX (glassy, for use on dark/photo) --- */
.btn-ghost-lux{
  background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.35);backdrop-filter:blur(8px);
}
.btn-ghost-lux:hover{transform:translateY(-2px);background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.6)}

/* sizes */
.btn-sm{padding:.6rem 1.1rem;font-size:.72rem;--btn-radius:10px}
.btn-lg{padding:1.05rem 2.4rem;font-size:.9rem;--btn-radius:14px}
.btn-block{display:flex;width:100%}
.btn-icon{padding:.78rem;aspect-ratio:1;--btn-radius:12px}
.btn-icon.btn-sm{padding:.55rem}

/* dark mode tweaks */
html.dark .btn-soft{background:rgba(184,147,90,.16);color:#e4c589;border-color:rgba(184,147,90,.35)}
html.dark .btn-outline{color:#e4c589;border-color:#b8935a}

/* ============================================================
   PREMIUM THEMES CATALOG
   ============================================================ */
.cat-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:.4rem}
.cat-head .cat-intro{max-width:560px}
.cat-head h2{font-family:'Fraunces',serif;font-weight:300;font-size:1.7rem;color:var(--ink);margin:0 0 .35rem}
.cat-head p{color:var(--muted);font-size:.92rem;line-height:1.6;margin:0}
.cat-filters{display:flex;gap:.5rem;flex-wrap:wrap}
.cat-chip{
  font-family:'Inter Tight',sans-serif;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;
  padding:.5rem 1rem;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--muted);
  cursor:pointer;transition:.25s;font-weight:500;
}
.cat-chip:hover{border-color:var(--gold);color:var(--gold)}
.cat-chip.active{background:linear-gradient(135deg,#E4C589,#B8935A);color:#fff;border-color:transparent;box-shadow:0 6px 16px -8px rgba(184,147,90,.6)}
html.dark .cat-chip{background:rgba(255,255,255,.04)}

.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.6rem;margin-top:1.6rem}
.cat-card{
  position:relative;border-radius:18px;overflow:hidden;background:#fff;border:1px solid var(--line);
  box-shadow:0 8px 30px -18px rgba(60,50,40,.4);
  transition:transform .45s cubic-bezier(.2,.8,.2,1),box-shadow .45s,border-color .45s;
}
html.dark .cat-card{background:rgba(255,255,255,.03)}
.cat-card:hover{transform:translateY(-8px);box-shadow:0 26px 48px -22px rgba(60,50,40,.55);border-color:rgba(184,147,90,.45)}
.cat-media{position:relative;aspect-ratio:4/5;background:linear-gradient(135deg,#f3ead8,#e7d9bf);overflow:hidden}
.cat-media .cat-img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.cat-card:hover .cat-img{transform:scale(1.07)}
.cat-media .cat-fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;color:rgba(140,108,60,.55)}
.cat-media .cat-fallback i{font-size:2.4rem}
.cat-media .cat-fallback span{font-family:'Fraunces',serif;font-size:1.1rem;letter-spacing:.02em}
.cat-media .cat-veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(38,34,29,.78) 0%,rgba(38,34,29,.05) 45%,transparent 70%)}

.cat-badges{position:absolute;top:.85rem;left:.85rem;right:.85rem;display:flex;justify-content:space-between;align-items:flex-start;z-index:2}
.cat-tier{font-family:'Inter Tight',sans-serif;font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.35rem .7rem;border-radius:999px;backdrop-filter:blur(6px)}
.cat-tier.free{background:rgba(255,255,255,.92);color:#6f7a3e}
.cat-tier.premium{background:linear-gradient(135deg,#E4C589,#B8935A);color:#fff;box-shadow:0 4px 12px -4px rgba(184,147,90,.7)}
.cat-fav{width:34px;height:34px;border-radius:50%;border:none;background:rgba(255,255,255,.85);color:var(--gold);cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);transition:.25s}
.cat-fav:hover{background:#fff;transform:scale(1.1)}

.cat-overlay{position:absolute;left:0;right:0;bottom:0;padding:1.1rem 1.2rem;z-index:2;color:#fff;transform:translateY(8px);opacity:.96;transition:.45s}
.cat-card:hover .cat-overlay{transform:translateY(0)}
.cat-overlay h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.25rem;margin:0 0 .2rem;color:#fff}
.cat-overlay p{font-size:.8rem;line-height:1.5;color:rgba(255,255,255,.82);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cat-actions{display:flex;gap:.55rem;padding:0 1.2rem 1.2rem;margin-top:-.2rem}
.cat-actions .btn{flex:1}

/* ============================================================
   HOW-TO-EDIT TUTORIAL  (step-by-step illustrated)
   ============================================================ */
.tut-hero{position:relative;border-radius:22px;overflow:hidden;padding:2.6rem 2.4rem;margin-bottom:2.4rem;
  background:linear-gradient(135deg,#26221d 0%,#3a352e 60%,#5a4a32 100%);color:#fff}
.tut-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 15%,rgba(228,197,137,.3),transparent 55%);pointer-events:none}
.tut-hero .tut-kicker{position:relative;font-family:'Inter Tight',sans-serif;font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:#e4c589;margin:0 0 .9rem}
.tut-hero h1{position:relative;font-family:'Fraunces',serif;font-weight:200;font-size:clamp(1.9rem,4vw,2.8rem);line-height:1.12;margin:0 0 .8rem;color:#fff}
.tut-hero p{position:relative;max-width:580px;color:rgba(255,255,255,.82);font-size:.98rem;line-height:1.7;margin:0 0 1.5rem}
.tut-hero .tut-cta{position:relative;display:flex;gap:.8rem;flex-wrap:wrap}
.tut-meta{position:relative;display:flex;gap:1.8rem;margin-top:1.7rem;flex-wrap:wrap}
.tut-meta span{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:rgba(255,255,255,.75)}
.tut-meta i{color:#e4c589}

.tut-steps{display:flex;flex-direction:column;gap:1.4rem;counter-reset:tut}
.tut-step{position:relative;display:grid;grid-template-columns:300px 1fr;gap:0;border-radius:20px;overflow:hidden;
  background:#fff;border:1px solid var(--line);box-shadow:0 10px 34px -22px rgba(60,50,40,.45);
  transition:transform .4s,box-shadow .4s}
html.dark .tut-step{background:rgba(255,255,255,.03)}
.tut-step:hover{transform:translateY(-4px);box-shadow:0 24px 46px -26px rgba(60,50,40,.5)}
.tut-step:nth-child(even){grid-template-columns:1fr 300px}
.tut-step:nth-child(even) .tut-art{order:2}
.tut-art{position:relative;background:linear-gradient(135deg,#faf6ef,#f1e6d2);display:flex;align-items:center;justify-content:center;padding:1.6rem;min-height:230px}
html.dark .tut-art{background:linear-gradient(135deg,#2a2620,#332d24)}
.tut-art svg{width:100%;max-width:230px;height:auto;filter:drop-shadow(0 8px 18px rgba(60,50,40,.18))}
.tut-body{padding:1.9rem 2rem;display:flex;flex-direction:column;justify-content:center}
.tut-num{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:13px;
  background:linear-gradient(135deg,#E4C589,#B8935A);color:#fff;font-family:'Fraunces',serif;font-size:1.25rem;font-weight:500;
  margin-bottom:1rem;box-shadow:0 8px 18px -8px rgba(184,147,90,.7)}
.tut-body h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.4rem;color:var(--ink);margin:0 0 .6rem}
.tut-body p{color:var(--muted);font-size:.94rem;line-height:1.7;margin:0 0 1rem}
.tut-tips{display:flex;flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none}
.tut-tips li{display:flex;align-items:flex-start;gap:.6rem;font-size:.86rem;color:var(--ink);line-height:1.5}
.tut-tips li i{color:var(--gold);margin-top:.18rem;font-size:.8rem}
.tut-cta-end{text-align:center;margin-top:2.6rem;padding:2.6rem 2rem;border-radius:20px;
  background:linear-gradient(135deg,rgba(184,147,90,.1),rgba(184,147,90,.04));border:1px solid rgba(184,147,90,.25)}
.tut-cta-end h2{font-family:'Fraunces',serif;font-weight:300;font-size:1.7rem;color:var(--ink);margin:0 0 .6rem}
.tut-cta-end p{color:var(--muted);margin:0 0 1.4rem}
.tut-cta-end .tut-cta{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

@media(max-width:720px){
  .tut-step,.tut-step:nth-child(even){grid-template-columns:1fr}
  .tut-step:nth-child(even) .tut-art{order:0}
  .tut-art{min-height:180px}
}

/* ============================================================
   STUDIO EDITOR  (Canva/CapCut-class visual editor)
   ============================================================ */
.se-studio{position:fixed;inset:0;display:flex;flex-direction:column;background:#f4f1ea;color:var(--ink);font-family:'Inter Tight',system-ui,sans-serif;z-index:50}
html.dark .se-studio{background:#16140f;color:#ece6da}

/* ---- top bar ---- */
.se-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:60px;padding:0 1rem;
  background:#fff;border-bottom:1px solid var(--line);box-shadow:0 1px 10px -6px rgba(60,50,40,.35);flex-shrink:0}
html.dark .se-topbar{background:#1d1a14;border-color:#332d24}
.se-top-left,.se-top-center,.se-top-right{display:flex;align-items:center;gap:.6rem}
.se-back{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--muted);text-decoration:none;transition:.2s}
.se-back:hover{background:rgba(184,147,90,.12);color:var(--gold)}
.se-logo{display:flex;align-items:center}.se-logo .jfy-mark{width:32px;height:32px}
.se-titlewrap{display:flex;align-items:center;gap:.6rem;margin-left:.3rem}
.se-title-input{font-family:'Fraunces',serif;font-size:1.05rem;font-weight:500;border:1px solid transparent;background:transparent;color:var(--ink);
  padding:.35rem .6rem;border-radius:9px;width:clamp(120px,22vw,300px);transition:.2s}
.se-title-input:hover{background:rgba(184,147,90,.08)}
.se-title-input:focus{outline:none;background:#fff;border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,147,90,.18)}
html.dark .se-title-input{color:#ece6da}html.dark .se-title-input:focus{background:#16140f}
.se-theme-chip{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;letter-spacing:.04em;color:var(--gold);
  background:rgba(184,147,90,.1);border:1px solid rgba(184,147,90,.25);padding:.32rem .7rem;border-radius:999px;white-space:nowrap}

.se-tool{width:36px;height:36px;border-radius:10px;border:none;background:transparent;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;font-size:.92rem}
.se-tool:hover{background:rgba(184,147,90,.12);color:var(--gold)}
.se-tool:disabled{opacity:.35;cursor:not-allowed}
.se-tool:disabled:hover{background:transparent;color:var(--muted)}
.se-sep{width:1px;height:22px;background:var(--line);margin:0 .2rem}
.se-savestate{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;color:#6f7a3e;padding:.3rem .6rem;border-radius:8px;transition:.3s}
.se-savestate.saving{color:var(--gold)}.se-savestate.err{color:#c0563f}
.se-savestate.saving i{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.se-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#E4C589,#B8935A);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;flex-shrink:0}

/* ---- workspace ---- */
.se-workspace{flex:1;display:flex;min-height:0}

/* icon rail */
.se-rail{width:76px;background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;padding:.8rem .4rem;gap:.3rem;flex-shrink:0}
html.dark .se-rail{background:#1d1a14;border-color:#332d24}
.se-rail-btn{width:100%;border:none;background:transparent;cursor:pointer;border-radius:12px;padding:.7rem .2rem;display:flex;flex-direction:column;align-items:center;gap:.3rem;color:var(--muted);transition:.2s;font-family:inherit}
.se-rail-btn i{font-size:1.15rem}
.se-rail-btn span{font-size:.62rem;letter-spacing:.03em;text-transform:uppercase;font-weight:500}
.se-rail-btn:hover{background:rgba(184,147,90,.1);color:var(--gold)}
.se-rail-btn.active{background:linear-gradient(135deg,rgba(228,197,137,.22),rgba(184,147,90,.16));color:var(--gold)}
.se-rail-btn.active i{filter:drop-shadow(0 2px 6px rgba(184,147,90,.4))}
.se-rail-spacer{flex:1}

/* contextual panel */
.se-panel{width:340px;background:#faf7f1;border-right:1px solid var(--line);overflow-y:auto;flex-shrink:0;padding:1.3rem 1.2rem 3rem}
html.dark .se-panel{background:#1a1711;border-color:#332d24}
.se-panel::-webkit-scrollbar{width:8px}.se-panel::-webkit-scrollbar-thumb{background:rgba(184,147,90,.3);border-radius:8px}
.se-tabpane{display:none}.se-tabpane.active{display:block;animation:sePaneIn .3s ease}
@keyframes sePaneIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.se-pane-head{margin-bottom:1.2rem}
.se-pane-head h2{font-family:'Fraunces',serif;font-weight:400;font-size:1.4rem;margin:0 0 .3rem;color:var(--ink)}
.se-pane-head p{font-size:.82rem;color:var(--muted);line-height:1.5;margin:0}

/* accordion */
.se-accordion{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:.8rem;overflow:hidden;transition:.25s}
html.dark .se-accordion{background:#221e17;border-color:#332d24}
.se-accordion.open{box-shadow:0 8px 24px -16px rgba(60,50,40,.45)}
.se-acc-head{width:100%;display:flex;align-items:center;gap:.7rem;padding:.95rem 1rem;border:none;background:transparent;cursor:pointer;font-family:inherit;color:var(--ink)}
html.dark .se-acc-head{color:#ece6da}
.se-acc-ico{width:30px;height:30px;border-radius:9px;background:rgba(184,147,90,.12);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:.82rem;flex-shrink:0}
.se-acc-title{flex:1;text-align:left;font-weight:600;font-size:.9rem}
.se-acc-chev{color:var(--muted);transition:transform .3s;font-size:.72rem}
.se-accordion.open .se-acc-chev{transform:rotate(180deg);color:var(--gold)}
.se-acc-body{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s;padding:0 1rem}
.se-accordion.open .se-acc-body{max-height:1400px;padding:0 1rem 1rem}

/* fields */
.se-field{margin-bottom:.95rem}
.se-field label{display:block;font-size:.78rem;font-weight:600;color:var(--ink);margin-bottom:.4rem}
html.dark .se-field label{color:#d8d0c2}
.se-req{color:#c0563f;margin-left:2px}
.se-input{width:100%;padding:.6rem .75rem;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.88rem;background:#fff;color:var(--ink);transition:.2s}
html.dark .se-input{background:#16140f;border-color:#3a332a;color:#ece6da}
.se-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,147,90,.16)}
.se-area{resize:vertical;min-height:70px;line-height:1.5}
.se-help{display:block;font-size:.72rem;color:var(--muted);margin-top:.3rem}
.se-field-flash{animation:seFlash 1.5s ease}
@keyframes seFlash{0%,100%{background:transparent}20%,60%{background:rgba(184,147,90,.14);box-shadow:0 0 0 6px rgba(184,147,90,.1);border-radius:10px}}

/* image control */
.se-image{display:flex;flex-direction:column;gap:.6rem}
.se-drop{display:flex;gap:.8rem;align-items:center;padding:.8rem;border:1.5px dashed rgba(184,147,90,.4);border-radius:12px;background:rgba(184,147,90,.04);transition:.2s}
.se-drop.drag{border-color:var(--gold);background:rgba(184,147,90,.12)}
.se-thumb{width:62px;height:62px;border-radius:10px;background:#f1e8d6;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;color:rgba(140,108,60,.5);font-size:1.2rem}
.se-thumb img{width:100%;height:100%;object-fit:cover}
.se-drop-body{display:flex;flex-direction:column;gap:.35rem;min-width:0}
.se-uploadbtn{cursor:pointer;align-self:flex-start}
.se-upstatus{font-size:.7rem;color:var(--muted)}.se-upstatus.ok{color:#6f7a3e}.se-upstatus.err{color:#c0563f}
.se-photo-grid{display:flex;flex-direction:column;gap:1rem}
.se-gallery{display:flex;flex-direction:column;gap:.7rem}
.se-gal-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
.se-gal-thumb{position:relative;aspect-ratio:3/4;border-radius:9px;overflow:hidden;background:#f1e8d6;cursor:grab;border:1px solid var(--line)}
.se-gal-thumb.dragging{opacity:.4}
.se-gal-thumb img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.se-gal-del{position:absolute;top:4px;right:4px;width:22px;height:22px;border:none;border-radius:50%;background:rgba(38,34,29,.78);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.65rem;transition:.2s}
.se-gal-del:hover{background:#c0563f}
.se-gal-handle{position:absolute;bottom:4px;left:4px;color:rgba(255,255,255,.85);font-size:.6rem;background:rgba(38,34,29,.55);border-radius:5px;padding:2px 5px;pointer-events:none}
.se-gal-add{align-self:flex-start;cursor:pointer}
/* audio field */
.se-audio{display:flex;flex-direction:column;gap:.5rem}
.se-audio-row{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.se-audio-preview{height:34px}
.se-select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%23B8935A' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right .85rem center;padding-right:2rem;cursor:pointer}
.se-empty-tab{text-align:center;color:var(--muted);padding:3rem 1rem}
.se-empty-tab i{font-size:2rem;color:rgba(184,147,90,.4);margin-bottom:.6rem;display:block}

/* design tab */
.se-section-label{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--muted);margin:1.3rem 0 .7rem}
.se-palettes{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.se-palette{border:1px solid var(--line);background:#fff;border-radius:12px;padding:.7rem;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;transition:.2s;font-family:inherit}
html.dark .se-palette{background:#221e17;border-color:#332d24}
.se-palette:hover{border-color:var(--gold);transform:translateY(-2px)}
.se-palette.active{border-color:var(--gold);box-shadow:0 0 0 2px rgba(184,147,90,.3)}
.se-pal-swatches{display:flex;height:24px;border-radius:6px;overflow:hidden}
.se-pal-swatches i{flex:1}
.se-pal-name{font-size:.72rem;color:var(--ink);font-weight:500}
html.dark .se-pal-name{color:#d8d0c2}
.se-fonts{display:flex;gap:.6rem}
.se-font{flex:1;border:1px solid var(--line);background:#fff;border-radius:12px;padding:.7rem .4rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.3rem;transition:.2s}
html.dark .se-font{background:#221e17;border-color:#332d24}
.se-font:hover{border-color:var(--gold)}
.se-font.active{border-color:var(--gold);box-shadow:0 0 0 2px rgba(184,147,90,.3)}
.se-font-sample{font-size:1.5rem;color:var(--gold);line-height:1}
.se-font-name{font-size:.66rem;color:var(--muted);font-family:'Inter Tight',sans-serif}
.se-accent-row{display:flex;gap:.5rem;align-items:center}
.se-color{width:46px;height:40px;border:1px solid var(--line);border-radius:10px;padding:2px;cursor:pointer;background:#fff}
.se-hex{flex:1;text-transform:uppercase;font-family:'JetBrains Mono',monospace;font-size:.82rem}
.se-note{font-size:.74rem;color:var(--muted);line-height:1.5;margin-top:1.2rem;display:flex;gap:.5rem}
.se-note i{color:var(--gold);margin-top:.15rem}

/* settings tab */
.se-link-row{display:flex;gap:.5rem}.se-link-row .se-input{font-family:'JetBrains Mono',monospace;font-size:.8rem}
.se-setting-cards{display:flex;flex-direction:column;gap:.7rem;margin-top:1rem}
.se-setting-card{display:flex;align-items:center;gap:.8rem;padding:.9rem;border:1px solid var(--line);border-radius:13px;text-decoration:none;color:var(--ink);background:#fff;transition:.2s}
html.dark .se-setting-card{background:#221e17;border-color:#332d24;color:#ece6da}
.se-setting-card:hover{border-color:var(--gold);transform:translateX(3px)}
.se-sc-ico{width:38px;height:38px;border-radius:11px;background:rgba(184,147,90,.12);color:var(--gold);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.se-setting-card span strong{display:block;font-size:.88rem}
.se-setting-card span small{font-size:.74rem;color:var(--muted)}
.se-setting-card>span{flex:1}
.se-setting-card>i{color:var(--muted);font-size:.78rem}
.se-danger{margin-top:1.6rem;padding:1.1rem;border:1px solid #e8c4ba;border-radius:13px;background:rgba(192,86,63,.04)}
.se-danger strong{display:block;color:#c0563f;font-size:.82rem;margin-bottom:.7rem}

/* help tab */
.se-tips{list-style:none;padding:0;margin:0 0 1.4rem;display:flex;flex-direction:column;gap:.9rem}
.se-tips li{display:flex;gap:.7rem;font-size:.85rem;line-height:1.5;color:var(--ink)}
html.dark .se-tips li{color:#d8d0c2}
.se-tips li i{color:var(--gold);margin-top:.15rem;flex-shrink:0}

/* ---- canvas ---- */
.se-canvas{flex:1;display:flex;flex-direction:column;min-width:0;background:radial-gradient(circle at 50% 0%,#efe9dd,#e4ddcd)}
html.dark .se-canvas{background:radial-gradient(circle at 50% 0%,#1e1a13,#13110c)}
.se-canvas-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 1.2rem;background:rgba(255,255,255,.55);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);flex-shrink:0}
html.dark .se-canvas-bar{background:rgba(29,26,20,.55);border-color:#332d24}
.se-device-toggle{display:flex;background:#fff;border:1px solid var(--line);border-radius:11px;padding:3px}
html.dark .se-device-toggle{background:#221e17;border-color:#332d24}
.se-dev{width:38px;height:32px;border:none;background:transparent;border-radius:8px;cursor:pointer;color:var(--muted);transition:.2s}
.se-dev:hover{color:var(--gold)}
.se-dev.active{background:linear-gradient(135deg,#E4C589,#B8935A);color:#fff;box-shadow:0 4px 10px -4px rgba(184,147,90,.6)}
.se-canvas-url{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--muted);font-family:'JetBrains Mono',monospace;background:#fff;border:1px solid var(--line);padding:.4rem .9rem;border-radius:999px}
html.dark .se-canvas-url{background:#221e17;border-color:#332d24}
.se-canvas-url i{font-size:.7rem;color:#6f7a3e}
.se-canvas-tools{display:flex;align-items:center;gap:.2rem}
.se-zoom-label{font-size:.74rem;color:var(--muted);min-width:42px;text-align:center;font-family:'JetBrains Mono',monospace}

.se-stage{flex:1;overflow:auto;display:flex;align-items:flex-start;justify-content:center;padding:2.4rem 1rem}
.se-device-frame{position:relative;background:#fff;border-radius:20px;box-shadow:0 30px 70px -30px rgba(40,32,22,.6),0 0 0 1px rgba(60,50,40,.06);transition:width .4s cubic-bezier(.2,.8,.2,1),height .4s,transform .25s;overflow:hidden;transform-origin:top center}
.se-device-frame.phone{width:390px;height:760px;border-radius:34px;padding:12px;background:#26221d}
.se-device-frame.phone::before{content:"";position:absolute;top:14px;left:50%;transform:translateX(-50%);width:90px;height:6px;border-radius:6px;background:rgba(255,255,255,.25);z-index:3}
.se-device-frame.phone .se-frame{border-radius:24px}
.se-device-frame.tablet{width:600px;height:800px;border-radius:24px;padding:14px;background:#26221d}
.se-device-frame.tablet .se-frame{border-radius:14px}
.se-device-frame.full{width:min(1100px,94%);height:760px;border-radius:14px;padding:0}
.se-frame{width:100%;height:100%;border:none;background:#fff;transition:opacity .3s;display:block}
.se-frame-loader{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:.6rem;background:rgba(255,255,255,.85);z-index:2;font-size:.85rem;color:var(--muted);border-radius:inherit}
.se-spinner{width:18px;height:18px;border:2.5px solid rgba(184,147,90,.3);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}

/* responsive */
@media(max-width:1000px){
  .se-rail{width:64px}.se-rail-btn span{display:none}
  .se-panel{width:300px}
}
@media(max-width:780px){
  .se-workspace{flex-direction:column}
  .se-rail{flex-direction:row;width:100%;height:auto;border-right:none;border-bottom:1px solid var(--line);justify-content:space-around;padding:.4rem}
  .se-rail-spacer{display:none}
  .se-rail-btn{flex-direction:row;gap:.4rem;width:auto;padding:.5rem .8rem}.se-rail-btn span{display:inline;font-size:.66rem}
  .se-panel{width:100%;max-height:42vh;border-right:none;border-bottom:1px solid var(--line)}
  .se-canvas-url{display:none}
  .se-title-input{width:120px}
  .se-top-center .se-savestate span,.se-theme-chip{display:none}
}
