:root{
  --bg:#faf8f3; --bg-2:#f1ede2; --bg-3:#e9e3d2;
  --ink:#0a0a0a; --ink-2:#1a1a1a; --ink-3:#3a3a3a;
  --muted:#6b6b6b;
  --line:#e2dfd2; --line-2:#d0ccbb;
  --accent:#ff5b1e; --accent-soft:#fff1e8; --accent-2:#ffb83d;
  --green:#1f8f5d;
  --shadow-sm:0 1px 0 rgba(0,0,0,.04), 0 4px 12px -4px rgba(0,0,0,.08);
  --shadow:0 1px 0 rgba(0,0,0,.04), 0 12px 40px -16px rgba(0,0,0,.14);
  --shadow-lg:0 30px 80px -20px rgba(0,0,0,.4);
  --radius:14px; --radius-lg:20px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'Inter Tight',sans-serif;-webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit}
img{max-width:100%;display:block}
::selection{background:var(--ink);color:var(--accent-2)}
ul{padding-left:0;list-style:none}

body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.03;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ========== NAV ========== */
.nav{position:sticky;top:0;z-index:100;background:rgba(250,248,243,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1320px;margin:0 auto;padding:18px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:flex;align-items:center;cursor:pointer;transition:opacity .2s}
.logo:hover{opacity:.85}
.logo-img{height:38px;width:auto;display:block}
.nav-links{display:flex;gap:30px;align-items:center;font-size:14.5px;font-weight:500}
.nav-links a{color:var(--ink-2);transition:color .2s;cursor:pointer}
.nav-links a:hover{color:var(--accent)}
.nav-cta{padding:11px 20px;background:var(--ink);color:#fff;border-radius:10px;font-weight:600;font-size:14px;transition:all .2s;cursor:pointer}
.nav-cta:hover{transform:translateY(-1px);background:var(--accent)}
.nav-burger{display:none;background:var(--bg-2);width:42px;height:42px;border-radius:10px;align-items:center;justify-content:center;color:var(--ink)}
.mobile-menu{display:none;flex-direction:column;background:#fff;border-bottom:1px solid var(--line);padding:14px 24px;gap:6px}
.mobile-menu a{padding:12px 4px;border-bottom:1px solid var(--line);font-weight:500;color:var(--ink-2);cursor:pointer}
.mobile-menu a:last-child{border-bottom:none}
.mobile-menu.open{display:flex}

/* ========== PAGES ========== */
.page{display:none}
.page.active{display:block}

/* ========== HERO ========== */
.hero{max-width:1320px;margin:0 auto;padding:90px 32px 70px;position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1.15fr .95fr;gap:64px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:#fff;border:1px solid var(--line);border-radius:100px;font-size:13px;font-weight:500;color:var(--ink-2);margin-bottom:28px;box-shadow:var(--shadow-sm)}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(31,143,93,.2);animation:pulse 1.8s infinite}

h1{font-family:'Fraunces',serif;font-size:clamp(46px,6.2vw,82px);line-height:.96;letter-spacing:-.038em;font-weight:600;margin-bottom:28px}
h1 em{font-style:italic;font-weight:500;color:var(--accent);position:relative}
h1 em::after{content:"";position:absolute;left:0;right:0;bottom:.05em;height:.08em;background:var(--accent);opacity:.25;border-radius:2px}
.hero p{font-size:19.5px;color:var(--muted);max-width:560px;margin-bottom:40px;line-height:1.55}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{padding:17px 30px;background:var(--ink);color:#fff;border-radius:12px;font-weight:600;font-size:15.5px;display:inline-flex;align-items:center;gap:10px;transition:all .25s;cursor:pointer}
.btn-primary:hover{background:var(--accent);transform:translateY(-2px);box-shadow:0 14px 34px -10px rgba(255,91,30,.55)}
.btn-secondary{padding:17px 26px;border:1.5px solid var(--ink);border-radius:12px;font-weight:600;font-size:15.5px;color:var(--ink);transition:all .2s;cursor:pointer;background:transparent}
.btn-secondary:hover{background:var(--ink);color:#fff}

.hero-stats{display:flex;gap:44px;margin-top:52px;flex-wrap:wrap}
.hero-stats .s{display:flex;flex-direction:column;gap:4px}
.hero-stats .num{font-family:'Fraunces',serif;font-size:38px;font-weight:600;letter-spacing:-.025em;line-height:1}
.hero-stats .lbl{font-size:12.5px;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}

.hero-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.hero-card::before{content:"";position:absolute;top:0;right:0;width:140px;height:140px;background:radial-gradient(circle at top right, var(--accent-soft), transparent 70%);pointer-events:none}
.hcard-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;position:relative}
.hcard-title{font-size:13px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.1em}
.hcard-pulse{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--green);font-weight:700;letter-spacing:.05em}
.hcard-pulse::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hcard-row{display:grid;grid-template-columns:1fr auto auto;gap:14px;align-items:center;padding:14px 0;border-bottom:1px dashed var(--line)}
.hcard-row:last-child{border:none;padding-bottom:0}
.hcard-site{font-family:'JetBrains Mono',monospace;font-size:13.5px;font-weight:500;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dr-pill{padding:3px 9px;background:var(--bg-2);border-radius:6px;font-size:11.5px;font-weight:700;font-family:'JetBrains Mono',monospace}
.dr-pill.high{background:#dcfce7;color:#166534}
.hcard-price{font-weight:700;font-size:14px;font-family:'JetBrains Mono',monospace}

/* ========== TRUST ========== */
.trust{padding:38px 32px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);position:relative;z-index:2}
.trust-inner{max-width:1320px;margin:0 auto;display:flex;align-items:center;gap:40px;flex-wrap:wrap;justify-content:space-around}
.trust-item{font-family:'Fraunces',serif;font-size:18px;font-weight:500;color:var(--ink-2);display:flex;align-items:center;gap:11px;font-style:italic}
.trust-item svg{flex-shrink:0;color:var(--accent)}

/* ========== SECTION HEAD ========== */
.section-head{margin-bottom:56px;max-width:720px}
.section-tag{font-size:12px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.14em;margin-bottom:18px;display:flex;align-items:center;gap:12px}
.section-tag::before{content:"";width:36px;height:1px;background:var(--accent)}
.section-head h2{font-family:'Fraunces',serif;font-size:clamp(34px,4.5vw,54px);line-height:1.04;letter-spacing:-.028em;font-weight:600;margin-bottom:18px}
.section-head h2 em{font-style:italic;font-weight:500;color:var(--accent)}
.section-head p{font-size:18px;color:var(--muted);line-height:1.55}

/* ========== HOW ========== */
.how{max-width:1320px;margin:0 auto;padding:110px 32px;position:relative;z-index:2}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.how-card{padding:30px;border:1px solid var(--line);border-radius:16px;background:#fff;transition:all .35s;position:relative;overflow:hidden}
.how-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.how-card:hover{border-color:var(--ink);transform:translateY(-4px);box-shadow:var(--shadow)}
.how-card:hover::before{transform:scaleX(1)}
.step-num{font-family:'Fraunces',serif;font-size:48px;font-weight:600;color:var(--accent);line-height:1;margin-bottom:24px;font-style:italic}
.how-card h3{font-family:'Fraunces',serif;font-size:23px;font-weight:600;letter-spacing:-.015em;margin-bottom:10px}
.how-card p{font-size:14.5px;color:var(--muted);line-height:1.55}

/* ========== DASHBOARD ========== */
.dashboard{background:#fff;border-top:1px solid var(--line);padding:110px 32px;position:relative;z-index:2}
.dash-inner{max-width:1320px;margin:0 auto}

.bulk-banner{display:flex;align-items:center;gap:14px;padding:16px 22px;background:linear-gradient(95deg,var(--accent),#ff8b5e);color:#fff;border-radius:12px;margin-bottom:28px;font-size:14.5px;line-height:1.5}
.bulk-banner svg{flex-shrink:0;color:#fff}
.bulk-banner b{font-weight:700}

.tabs{display:flex;gap:8px;margin-bottom:28px;flex-wrap:wrap}
.tab{padding:12px 22px;border:1.5px solid var(--line);border-radius:100px;font-weight:600;font-size:14.5px;color:var(--ink-2);background:#fff;display:flex;align-items:center;gap:10px;transition:all .2s}
.tab .count{padding:2px 9px;background:var(--bg-2);border-radius:100px;font-size:11.5px;font-weight:700;font-family:'JetBrains Mono',monospace}
.tab:hover{border-color:var(--ink-3)}
.tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.tab.active .count{background:rgba(255,255,255,.18);color:#fff}

.dash-controls{display:grid;grid-template-columns:1fr 200px 180px;gap:14px;margin-bottom:24px;align-items:center}
.search-wrap{position:relative}
.search-wrap input{width:100%;padding:14px 18px 14px 46px;border:1.5px solid var(--line);border-radius:12px;font-size:14.5px;background:#fff;outline:none;transition:border-color .2s}
.search-wrap input:focus{border-color:var(--ink)}
.search-wrap svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--muted)}
.sort-select{padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;font-size:14.5px;font-weight:500;background:#fff;outline:none;cursor:pointer}
.dr-filter{display:flex;align-items:center;gap:10px;padding:0 16px;background:var(--bg-2);border-radius:12px;height:48px;font-size:13.5px;font-weight:500}
.dr-filter input{width:60px;padding:6px 8px;border:1px solid var(--line);border-radius:6px;font-family:'JetBrains Mono',monospace;font-size:13px;outline:none}
.dr-filter input:focus{border-color:var(--ink)}

.sites-table{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff}
.sites-thead{display:grid;grid-template-columns:60px 2fr 1.2fr 1fr 100px 1fr 140px;gap:16px;padding:16px 24px;background:var(--bg-2);font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);border-bottom:1px solid var(--line)}
.sites-tbody{max-height:680px;overflow-y:auto}
.sites-tbody::-webkit-scrollbar{width:8px}
.sites-tbody::-webkit-scrollbar-track{background:var(--bg-2)}
.sites-tbody::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}
.site-row{display:grid;grid-template-columns:60px 2fr 1.2fr 1fr 100px 1fr 140px;gap:16px;padding:18px 24px;align-items:center;border-bottom:1px solid var(--line);transition:background .15s}
.site-row:hover{background:var(--bg)}
.site-row:last-child{border-bottom:none}
.site-row .idx{color:var(--muted);font-size:12.5px;font-family:'JetBrains Mono',monospace}
.site-row .domain{font-weight:600;font-size:15px;font-family:'JetBrains Mono',monospace;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.site-row .dr{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:14px;display:flex;align-items:center;gap:10px}
.dr-bar{width:60px;height:6px;background:var(--bg-2);border-radius:100px;overflow:hidden;flex-shrink:0}
.dr-bar i{display:block;height:100%;background:linear-gradient(90deg,#1f6feb,var(--accent));border-radius:100px}
.site-row .traffic{font-family:'JetBrains Mono',monospace;font-size:14px;color:var(--ink-2)}
.site-row .price{font-weight:700;font-size:15px;font-family:'JetBrains Mono',monospace}
.dofollow-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:#dcfce7;color:#166534;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.04em}
.dofollow-pill::before{content:"";width:6px;height:6px;border-radius:50%;background:#166534}

.select-btn{padding:10px 16px;border:1.5px solid var(--ink);border-radius:8px;font-weight:600;font-size:13px;color:var(--ink);background:#fff;transition:all .15s;width:100%}
.select-btn:hover{background:var(--ink);color:#fff}
.select-btn.in-cart{background:var(--green);color:#fff;border-color:var(--green)}
.select-btn.in-cart:hover{background:#176e48;border-color:#176e48}

.sites-foot{padding:18px 24px;background:var(--bg-2);font-size:13px;color:var(--muted);text-align:center;border-top:1px solid var(--line);font-weight:500}
.sites-foot b{color:var(--ink);font-weight:700}

.empty{padding:80px 24px;text-align:center;color:var(--muted)}
.empty h4{font-family:'Fraunces',serif;font-size:22px;color:var(--ink);margin-bottom:8px}

/* Home page: cross-sell to full catalog (Health/Finance) */
.full-cat-cta{margin-top:32px;padding:32px 36px;background:linear-gradient(135deg,var(--ink) 0%,#1f1f1f 100%);border-radius:18px;display:flex;align-items:center;justify-content:space-between;gap:32px;color:#fff;flex-wrap:wrap;position:relative;overflow:hidden}
.full-cat-cta::before{content:"";position:absolute;top:0;right:0;width:240px;height:240px;background:radial-gradient(circle at top right, rgba(255,91,30,.18), transparent 60%);pointer-events:none}
.full-cat-cta h4{font-family:'Fraunces',serif;font-size:24px;font-weight:600;letter-spacing:-.018em;margin-bottom:6px;position:relative}
.full-cat-cta p{font-size:14.5px;color:#aaa;line-height:1.55;max-width:520px;position:relative}
.full-cat-cta .btn-primary{background:var(--accent);position:relative;flex-shrink:0}
.full-cat-cta .btn-primary:hover{background:#e64a0d}

/* Tabs full (5 cats) — wrap nicely on mobile */
.tabs-full{flex-wrap:wrap}

/* ========== CART FAB ========== */
.cart-fab{position:fixed;bottom:24px;right:24px;background:var(--ink);color:#fff;padding:16px 22px;border-radius:100px;font-weight:600;font-size:14px;display:flex;align-items:center;gap:14px;box-shadow:0 18px 40px -10px rgba(0,0,0,.4);cursor:pointer;z-index:90;transition:all .25s;transform:translateY(120px);border:none}
.cart-fab.show{transform:translateY(0)}
.cart-fab:hover{background:var(--accent);transform:translateY(-2px)}
.cart-fab .badge{background:var(--accent);padding:3px 11px;border-radius:100px;font-size:13px;font-weight:700;font-family:'JetBrains Mono',monospace;letter-spacing:-.01em}
.cart-fab:hover .badge{background:#fff;color:var(--accent)}
.cart-fab svg{flex-shrink:0}

/* ========== MODAL ========== */
.modal-bg{position:fixed;inset:0;background:rgba(10,10,10,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;display:none;align-items:center;justify-content:center;padding:24px;overflow-y:auto}
.modal-bg.show{display:flex}
.modal{background:#fff;border-radius:var(--radius-lg);max-width:780px;width:100%;max-height:92vh;overflow-y:auto;position:relative;box-shadow:var(--shadow-lg)}
.modal-close{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:50%;background:var(--bg-2);display:grid;place-items:center;cursor:pointer;z-index:10;transition:background .15s}
.modal-close:hover{background:var(--line)}
.modal-head{padding:38px 42px 26px;border-bottom:1px solid var(--line)}
.modal-head h2{font-family:'Fraunces',serif;font-size:30px;font-weight:600;letter-spacing:-.022em;margin-bottom:8px}
.modal-head p{color:var(--muted);font-size:15px;line-height:1.5}
.modal-body{padding:32px 42px}
.modal-h3{font-family:'Fraunces',serif;font-size:20px;font-weight:600;margin-bottom:14px;letter-spacing:-.012em}

.cart-list{margin-bottom:14px;max-height:280px;overflow-y:auto;padding-right:4px}
.cart-list::-webkit-scrollbar{width:6px}
.cart-list::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:6px}
.cart-item{display:grid;grid-template-columns:1fr auto auto;gap:14px;padding:14px 16px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;align-items:center;background:#fff;transition:all .15s}
.cart-item:hover{border-color:var(--line-2);background:var(--bg)}
.cart-item .ci-name{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:14px;letter-spacing:-.01em}
.cart-item .ci-meta{font-size:12px;color:var(--muted);margin-top:3px}
.cart-item .ci-price{font-weight:700;font-family:'JetBrains Mono',monospace;font-size:15px}
.cart-item .ci-rm{width:28px;height:28px;border-radius:50%;background:var(--bg-2);display:grid;place-items:center;cursor:pointer;color:var(--muted);transition:all .15s;border:none}
.cart-item .ci-rm:hover{background:#fee;color:#c00}

.add-more-btn{padding:11px 18px;background:var(--bg-2);border:1.5px dashed var(--line-2);border-radius:10px;font-weight:600;font-size:13.5px;color:var(--ink-2);cursor:pointer;transition:all .15s;width:100%;margin-bottom:4px}
.add-more-btn:hover{background:#fff;border-color:var(--ink);border-style:solid}

.option-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:28px}
.option{padding:24px;border:2px solid var(--line);border-radius:14px;cursor:pointer;transition:all .2s;position:relative;background:#fff}
.option:hover{border-color:var(--ink-3)}
.option.selected{border-color:var(--accent);background:var(--accent-soft)}
.option.selected::after{content:"✓";position:absolute;top:14px;right:14px;width:24px;height:24px;background:var(--accent);color:#fff;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px}
.option .opt-tag{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}
.option.selected .opt-tag{color:var(--accent)}
.option h4{font-family:'Fraunces',serif;font-size:20px;font-weight:600;margin-bottom:6px;letter-spacing:-.012em}
.option p{font-size:13.5px;color:var(--muted);line-height:1.5}
.option .opt-price{margin-top:14px;font-weight:700;font-family:'JetBrains Mono',monospace;font-size:15px;color:var(--ink)}

.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:8px;color:var(--ink-2)}
.field label .req{color:var(--accent)}
.field label .opt{color:var(--muted);font-weight:500}
.field input,.field textarea{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:10px;font-size:14.5px;background:#fff;outline:none;transition:border-color .2s;color:var(--ink)}
.field input:focus,.field textarea:focus{border-color:var(--ink)}
.field textarea{min-height:110px;resize:vertical;font-family:inherit;line-height:1.5}
.field .hint{font-size:12.5px;color:var(--muted);margin-top:6px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.file-drop{border:2px dashed var(--line-2);border-radius:12px;padding:28px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg)}
.file-drop:hover,.file-drop.drag{border-color:var(--accent);background:var(--accent-soft)}
.file-drop svg{margin:0 auto 12px;color:var(--muted)}
.file-drop strong{display:block;font-size:14.5px;margin-bottom:4px}
.file-drop span{font-size:12.5px;color:var(--muted)}
.file-list{margin-top:12px}
.file-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;background:var(--bg-2);border-radius:8px;font-size:13px;margin:4px 4px 0 0}
.file-chip .x{cursor:pointer;color:var(--muted);font-weight:700;font-size:16px;line-height:1}
.file-chip .x:hover{color:#c00}

.summary{padding:22px;background:var(--bg-2);border-radius:14px;margin-top:24px}
.summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14.5px}
.summary-row.discount{color:var(--green);font-weight:600}
.summary-row.total{border-top:1px solid var(--line-2);margin-top:10px;padding-top:14px;font-size:18px;font-weight:700;font-family:'Fraunces',serif}

.notice{padding:14px 16px;background:var(--accent-soft);border:1px solid #ffd9c2;border-radius:10px;font-size:13.5px;color:#7a3818;margin-top:18px;display:flex;gap:10px;align-items:flex-start;line-height:1.55}
.notice svg{flex-shrink:0;margin-top:2px}
.notice.success{background:#dcfce7;border-color:#bbf7d0;color:#166534}

.modal-foot{padding:24px 42px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:14px;background:var(--bg);position:sticky;bottom:0}
.modal-foot .price-display{font-family:'Fraunces',serif;font-size:22px;font-weight:600;letter-spacing:-.02em}
.modal-foot .price-display small{font-size:13px;color:var(--muted);font-family:'Inter Tight',sans-serif;font-weight:500;display:block;margin-top:-2px}
.btn-submit{padding:14px 28px;background:var(--ink);color:#fff;border-radius:10px;font-weight:700;font-size:15px;transition:all .2s;display:inline-flex;align-items:center;gap:10px;cursor:pointer}
.btn-submit:hover:not(:disabled){background:var(--accent);transform:translateY(-2px)}
.btn-submit:disabled{opacity:.4;cursor:not-allowed}

.success{padding:60px 42px;text-align:center}
.success-icon{width:84px;height:84px;border-radius:50%;background:#dcfce7;color:var(--green);display:grid;place-items:center;margin:0 auto 24px;animation:pop .55s cubic-bezier(.17,.84,.44,1)}
@keyframes pop{0%{transform:scale(0)}65%{transform:scale(1.18)}100%{transform:scale(1)}}
.success h2{font-family:'Fraunces',serif;font-size:36px;font-weight:600;letter-spacing:-.022em;margin-bottom:12px}
.success > p{color:var(--muted);font-size:16px;line-height:1.55;max-width:520px;margin:0 auto 22px}
.success .order-id{display:inline-block;padding:8px 16px;background:var(--bg-2);border-radius:8px;font-family:'JetBrains Mono',monospace;font-weight:600;font-size:14px;margin-bottom:24px}
.success-info{padding:24px;background:#f0f9f0;border:1px solid #c8e6c9;border-radius:12px;text-align:left;font-size:14px;line-height:1.65;color:#1f4d2e;margin-top:8px}
.success-info strong{color:#0d3818}
.success-info .step{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px}
.success-info .step:last-child{margin-bottom:0}
.success-info .step-icon{width:24px;height:24px;background:var(--green);color:#fff;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0;font-family:'JetBrains Mono',monospace}
.success-actions{margin-top:26px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* ========== TESTIMONIALS ========== */
.testimonials{padding:110px 32px;background:var(--bg-2);border-top:1px solid var(--line);position:relative;z-index:2}
.testi-inner{max-width:1320px;margin:0 auto}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testi-card{padding:34px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);transition:all .25s}
.testi-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.stars{color:var(--accent);font-size:18px;letter-spacing:2px;margin-bottom:18px}
.testi-card p{font-family:'Fraunces',serif;font-size:18px;font-style:italic;line-height:1.55;color:var(--ink-2);font-weight:500;margin-bottom:24px;letter-spacing:-.005em}
.testi-author{display:flex;align-items:center;gap:12px}
.ta-avatar{width:42px;height:42px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:700;font-size:16px;font-family:'Fraunces',serif}
.testi-author b{display:block;font-size:14.5px;color:var(--ink);font-weight:600}
.testi-author span{font-size:12.5px;color:var(--muted)}

/* ========== STATIC PAGES ========== */
.static-hero{max-width:1320px;margin:0 auto;padding:80px 32px 30px;position:relative;z-index:2}
.static-hero .eyebrow{margin-bottom:22px}
.static-hero h1{font-size:clamp(42px,5.5vw,72px);max-width:840px;margin-bottom:24px}
.static-hero p{font-size:19px;max-width:640px;color:var(--muted);line-height:1.55}
.static-content{max-width:880px;margin:0 auto;padding:40px 32px 100px;position:relative;z-index:2}
.static-content h3{font-family:'Fraunces',serif;font-size:26px;font-weight:600;letter-spacing:-.018em;margin:36px 0 14px;color:var(--ink)}
.static-content h3:first-child{margin-top:0}
.static-content p{font-size:16px;color:var(--ink-2);line-height:1.7;margin-bottom:14px}
.static-content ul{list-style:none;padding:0;margin:14px 0 22px}
.static-content ul li{position:relative;padding-left:22px;margin-bottom:12px;font-size:15.5px;color:var(--ink-2);line-height:1.6}
.static-content ul li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:8px;background:var(--accent);border-radius:50%}
.static-content ul li b{color:var(--ink)}
.static-content a{color:var(--accent);font-weight:600}
.static-cta{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}

/* ========== FAQ PAGE ========== */
.faq-content{max-width:980px;margin:0 auto;padding:30px 32px 100px;position:relative;z-index:2}
.faq-grid{display:grid;gap:14px}
.faq-item{border:1px solid var(--line);border-radius:14px;background:#fff;overflow:hidden;transition:border-color .2s}
.faq-item:hover{border-color:var(--line-2)}
.faq-q{padding:22px 26px;font-family:'Fraunces',serif;font-size:19px;font-weight:500;letter-spacing:-.012em;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq-q::after{content:"+";font-size:28px;font-weight:300;color:var(--muted);transition:transform .25s;line-height:1}
.faq-item.open .faq-q::after{transform:rotate(45deg);color:var(--accent)}
.faq-a{padding:0 26px;max-height:0;overflow:hidden;transition:all .35s ease;color:var(--muted);font-size:15px;line-height:1.65}
.faq-item.open .faq-a{padding:0 26px 22px;max-height:400px}
.faq-a b{color:var(--ink-2)}

/* ========== CONTACT PAGE ========== */
.contact-grid{max-width:1320px;margin:0 auto;padding:30px 32px 100px;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;position:relative;z-index:2}
.contact-info{display:flex;flex-direction:column;gap:18px}
.contact-card{padding:28px;background:#fff;border:1px solid var(--line);border-radius:16px;transition:all .25s;display:flex;gap:18px;align-items:flex-start;box-shadow:var(--shadow-sm)}
.contact-card:hover{border-color:var(--ink-3);transform:translateY(-2px);box-shadow:var(--shadow)}
.contact-card .ic{width:48px;height:48px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex-shrink:0}
.contact-card h4{font-family:'Fraunces',serif;font-size:20px;font-weight:600;letter-spacing:-.01em;margin-bottom:4px}
.contact-card p{font-size:14px;color:var(--muted);line-height:1.55;margin-bottom:8px}
.contact-card a{color:var(--accent);font-weight:600;font-size:15px;font-family:'JetBrains Mono',monospace;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.contact-card a:hover{gap:10px}

.contact-form-wrap{padding:38px;background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.contact-form-wrap::before{content:"";position:absolute;top:0;right:0;width:180px;height:180px;background:radial-gradient(circle at top right, var(--accent-soft), transparent 70%);pointer-events:none}
.contact-form-wrap h3{font-family:'Fraunces',serif;font-size:26px;font-weight:600;letter-spacing:-.018em;margin-bottom:6px;position:relative}
.contact-form-wrap > p{color:var(--muted);font-size:15px;margin-bottom:24px;position:relative}
.contact-form{position:relative}
.btn-contact-submit{padding:15px 28px;background:var(--ink);color:#fff;border-radius:10px;font-weight:700;font-size:15px;transition:all .2s;display:inline-flex;align-items:center;gap:10px;cursor:pointer;width:100%;justify-content:center;border:none}
.btn-contact-submit:hover{background:var(--accent);transform:translateY(-2px)}
.contact-success{padding:32px;background:#f0f9f0;border:1px solid #c8e6c9;border-radius:14px;text-align:center;display:none}
.contact-success.show{display:block}
.contact-success .ic{width:60px;height:60px;border-radius:50%;background:#dcfce7;color:var(--green);display:grid;place-items:center;margin:0 auto 16px}
.contact-success h4{font-family:'Fraunces',serif;font-size:22px;font-weight:600;margin-bottom:8px;color:#0d3818}
.contact-success p{color:#1f4d2e;font-size:14.5px;line-height:1.55}

/* ========== FOOTER ========== */
footer{background:var(--ink);color:#fff;padding:90px 32px 40px;margin-top:60px;position:relative;z-index:2}
.foot-inner{max-width:1320px;margin:0 auto}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
.foot-logo-img{height:130px;width:auto;display:block;margin-bottom:24px;margin-left:-12px}
.foot-tag{color:#999;font-size:14.5px;line-height:1.6;max-width:360px;margin-bottom:24px}
.foot-mail{display:inline-flex;align-items:center;gap:10px;padding:11px 18px;background:rgba(255,255,255,.08);border-radius:10px;font-size:14px;color:#fff;font-weight:500;transition:background .2s;font-family:'JetBrains Mono',monospace;letter-spacing:-.01em}
.foot-mail:hover{background:rgba(255,255,255,.15)}
.foot-col h5{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:#888;margin-bottom:18px;font-weight:700}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:11px}
.foot-col a{color:#ddd;font-size:14.5px;transition:color .15s;cursor:pointer}
.foot-col a:hover{color:var(--accent)}
.foot-bot{padding-top:32px;border-top:1px solid #2a2a2a;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;color:#888;font-size:13px}

/* ========== RESPONSIVE ========== */
@media (max-width:1024px){
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .testi-grid{grid-template-columns:1fr;gap:18px}
}
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .how-grid{grid-template-columns:repeat(2,1fr)}
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:flex}
  .foot-top{grid-template-columns:1fr 1fr;gap:32px}
  .sites-thead{display:none}
  .site-row{grid-template-columns:1fr 1fr;padding:16px;gap:8px}
  .site-row .idx{display:none}
  .site-row .domain{grid-column:1/-1;font-size:14px}
  .site-row .traffic,.site-row .dr{font-size:13px}
  .site-row .dofollow-pill{font-size:10px}
  .select-btn{grid-column:1/-1}
  .dash-controls{grid-template-columns:1fr}
  .option-grid{grid-template-columns:1fr}
  .modal-head,.modal-body,.modal-foot{padding-left:24px;padding-right:24px}
  .success{padding:40px 24px}
  .modal-foot{flex-direction:column;align-items:stretch}
  .modal-foot .btn-submit{justify-content:center}
  .field-row{grid-template-columns:1fr}
}
@media (max-width:560px){
  .hero{padding:48px 20px 32px}
  .nav-inner{padding:14px 20px}
  .how,.dashboard,.testimonials,.faq-content{padding-left:20px;padding-right:20px;padding-top:64px;padding-bottom:64px}
  .how-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .hero-stats{gap:24px}
  .hero-stats .num{font-size:28px}
  h1{font-size:42px}
  footer{padding:56px 20px 32px}
  .static-hero,.contact-grid,.static-content,.faq-content{padding-left:20px;padding-right:20px}
  .contact-form-wrap{padding:26px}
  .logo-img{height:32px}
  .foot-logo-img{height:110px}
  .cart-fab{bottom:18px;right:18px;padding:14px 18px;font-size:13px}
  .testi-card{padding:28px}
  .testi-card p{font-size:16px}
  .bulk-banner{font-size:13.5px;padding:14px 18px}
  .full-cat-cta{padding:24px;flex-direction:column;align-items:flex-start;text-align:left}
  .full-cat-cta .btn-primary{width:100%;justify-content:center}
}

/* =========================================================
   ============ AUTH / DASHBOARD / ADMIN STYLES ============
   ========================================================= */

/* ---------- NAV: auth-aware right side ---------- */
.nav-auth { display:flex; align-items:center; gap:14px; }
.nav-auth-out, .nav-auth-in { display:flex; align-items:center; gap:14px; }
.nav-login {
  color:var(--ink); font-weight:600; font-size:14px;
  cursor:pointer; padding:8px 14px; border-radius:10px;
  transition:background .15s ease;
}
.nav-login:hover { background:#f3f3f1; }

.nav-dash, .nav-admin {
  display:inline-flex; align-items:center; gap:7px;
  color:var(--ink); font-weight:600; font-size:13.5px;
  cursor:pointer; padding:8px 14px; border-radius:10px;
  text-decoration:none; transition:background .15s ease;
}
.nav-dash:hover { background:#f3f3f1; }
.nav-admin {
  background:linear-gradient(135deg, #ff5b1e, #ff7a3d);
  color:#fff;
}
.nav-admin:hover { background:linear-gradient(135deg, #e54a10, #ff5b1e); }

.nav-user-menu { position:relative; }
.nav-user-btn {
  display:inline-flex; align-items:center; gap:9px;
  background:#f8f7f4; border:1px solid #e8e6e0;
  padding:6px 12px 6px 6px; border-radius:999px;
  cursor:pointer; font-family:inherit; color:var(--ink);
  transition:all .15s ease;
}
.nav-user-btn:hover { background:#f0eee8; border-color:#d6d3cc; }
.nav-user-avatar {
  width:28px; height:28px; border-radius:50%;
  background:linear-gradient(135deg, #ff5b1e, #ff7a3d);
  color:#fff; font-weight:700; font-size:13px;
  display:inline-flex; align-items:center; justify-content:center;
}
.nav-user-name { font-weight:600; font-size:13.5px; }

.nav-user-dropdown {
  position:absolute; top:calc(100% + 8px); right:0;
  width:240px; background:#fff;
  border:1px solid #e8e6e0; border-radius:14px;
  box-shadow:0 18px 48px -12px rgba(0,0,0,.18);
  padding:6px; opacity:0; visibility:hidden;
  transform:translateY(-6px); transition:all .18s ease;
  z-index:1000;
}
.nav-user-dropdown.open { opacity:1; visibility:visible; transform:translateY(0); }
.nav-user-info { padding:12px 14px 14px; border-bottom:1px solid #f0eee8; margin-bottom:6px; }
.nav-user-info-name { font-weight:700; font-size:14px; color:var(--ink); margin-bottom:2px; }
.nav-user-info-email { font-size:12.5px; color:var(--muted); word-break:break-all; }
.nav-user-dropdown a {
  display:block; padding:10px 14px; border-radius:8px;
  font-size:14px; color:var(--ink); cursor:pointer;
  text-decoration:none; transition:background .12s ease;
}
.nav-user-dropdown a:hover { background:#f5f4f0; }
.nav-user-dropdown .nav-user-logout {
  color:#c0392b; border-top:1px solid #f0eee8;
  margin-top:6px; padding-top:12px; border-radius:0 0 8px 8px;
}

/* ---------- Mobile menu auth section ---------- */
.mobile-menu-divider {
  height:1px; background:#e8e6e0;
  margin:8px 16px;
}

/* ---------- AUTH PAGE ---------- */
.auth-section {
  padding:80px 24px 100px;
  min-height:calc(100vh - 200px);
  background:linear-gradient(180deg, #faf9f6 0%, #fff 100%);
}
.auth-wrap {
  max-width:1100px; margin:0 auto;
  display:grid; grid-template-columns:1fr 380px; gap:48px;
  align-items:start;
}
.auth-card {
  background:#fff;
  border:1px solid #e8e6e0;
  border-radius:20px;
  padding:36px 40px 44px;
  box-shadow:0 24px 64px -28px rgba(0,0,0,.12);
}
.auth-tabs {
  display:flex; gap:6px;
  background:#f5f4f0; padding:5px;
  border-radius:12px; margin-bottom:32px;
}
.auth-tab {
  flex:1; padding:11px; background:none; border:0;
  font-family:'Inter Tight',sans-serif;
  font-weight:600; font-size:14px; color:var(--muted);
  cursor:pointer; border-radius:8px;
  transition:all .15s ease;
}
.auth-tab.active { background:#fff; color:var(--ink); box-shadow:0 1px 3px rgba(0,0,0,.06); }

.auth-h {
  font-family:'Fraunces',serif;
  font-size:32px; font-weight:600;
  line-height:1.15; margin:0 0 8px;
  color:var(--ink); letter-spacing:-.5px;
}
.auth-sub {
  color:var(--muted); font-size:14.5px; line-height:1.55;
  margin:0 0 28px;
}
.auth-field { margin-bottom:18px; }
.auth-field label {
  display:block; font-size:13px; font-weight:600;
  color:var(--ink); margin-bottom:7px;
}
.auth-field input {
  width:100%; padding:13px 16px;
  background:#faf9f6; border:1px solid #e8e6e0;
  border-radius:10px; font-family:inherit;
  font-size:14.5px; color:var(--ink);
  transition:all .15s ease;
}
.auth-field input:focus {
  outline:none; border-color:var(--accent);
  background:#fff;
  box-shadow:0 0 0 3px rgba(255,91,30,.12);
}
.auth-err {
  color:#c0392b; font-size:13.5px; font-weight:500;
  min-height:20px; margin-bottom:14px;
}
.auth-btn {
  width:100%; padding:14px !important;
  justify-content:center; font-size:15px !important;
  margin-top:6px;
}
.auth-switch {
  text-align:center; margin:22px 0 0;
  color:var(--muted); font-size:14px;
}
.auth-switch a {
  color:var(--accent); font-weight:600; cursor:pointer;
  text-decoration:none;
}
.auth-switch a:hover { text-decoration:underline; }

/* Auth side panel */
.auth-side {
  padding:8px 0;
}
.auth-side h3 {
  font-family:'Fraunces',serif;
  font-size:22px; font-weight:600;
  margin:0 0 24px; color:var(--ink);
}
.auth-points {
  list-style:none; padding:0; margin:0 0 32px;
  display:flex; flex-direction:column; gap:14px;
}
.auth-points li {
  display:flex; align-items:flex-start; gap:11px;
  font-size:14.5px; color:#3d3d3a; line-height:1.5;
}
.auth-points svg {
  color:var(--accent); flex-shrink:0; margin-top:2px;
}
.auth-side-foot {
  padding:16px 18px;
  background:#f5f4f0; border-radius:12px;
  font-size:13px; line-height:1.6; color:var(--muted);
}
.auth-side-foot a {
  color:var(--accent); font-weight:500;
  text-decoration:none; cursor:pointer;
}
.auth-side-foot a:hover { text-decoration:underline; }

@media (max-width: 860px) {
  .auth-wrap { grid-template-columns:1fr; gap:32px; }
  .auth-card { padding:28px 24px 36px; }
  .auth-h { font-size:26px; }
}

/* ---------- DASHBOARD ---------- */
.dash-section {
  padding:48px 24px 100px;
  background:#faf9f6;
  min-height:calc(100vh - 200px);
}
.dash-wrap {
  max-width:1200px; margin:0 auto;
}
.dash-head {
  display:flex; justify-content:space-between;
  align-items:flex-end; gap:24px; margin-bottom:36px;
  flex-wrap:wrap;
}
.dash-h {
  font-family:'Fraunces',serif;
  font-size:42px; font-weight:600; line-height:1.1;
  margin:8px 0 6px; color:var(--ink); letter-spacing:-1px;
}
.dash-sub { color:var(--muted); font-size:15px; margin:0; }

.eyebrow-admin { color:#ff5b1e; }

.dash-stats {
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:16px; margin-bottom:32px;
}
.dash-stat {
  background:#fff; border:1px solid #e8e6e0;
  border-radius:14px; padding:20px 22px;
  position:relative; overflow:hidden;
}
.dash-stat::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px; background:linear-gradient(90deg, var(--accent), #ff8a55);
  opacity:.5;
}
.dash-stat-admin::before { opacity:1; }
.dash-stat-lbl {
  font-size:12px; font-weight:600;
  color:var(--muted); text-transform:uppercase;
  letter-spacing:.6px; margin-bottom:6px;
}
.dash-stat-num {
  font-family:'Fraunces',serif;
  font-size:32px; font-weight:600;
  color:var(--ink); line-height:1;
}

.dash-card {
  background:#fff; border:1px solid #e8e6e0;
  border-radius:18px; padding:28px 30px 32px;
  box-shadow:0 2px 8px rgba(0,0,0,.02);
}
.dash-card-head {
  display:flex; justify-content:space-between;
  align-items:center; margin-bottom:22px;
  flex-wrap:wrap; gap:14px;
}
.dash-card-head h3 {
  font-family:'Fraunces',serif;
  font-size:22px; font-weight:600;
  margin:0; color:var(--ink);
}
.dash-filter {
  display:flex; gap:10px; align-items:center;
}
.dash-filter input,
.dash-filter select {
  padding:9px 14px;
  background:#faf9f6; border:1px solid #e8e6e0;
  border-radius:9px; font-family:inherit;
  font-size:13.5px; color:var(--ink); cursor:pointer;
  min-width:150px;
}
.dash-filter input:focus,
.dash-filter select:focus {
  outline:none; border-color:var(--accent);
  background:#fff;
}

.dash-loading {
  padding:40px; text-align:center;
  color:var(--muted); font-size:14px;
}
.dash-empty {
  padding:50px 24px; text-align:center; color:var(--muted);
}
.dash-empty svg { color:#ccc; margin-bottom:14px; }
.dash-empty h4 {
  font-family:'Fraunces',serif;
  font-size:20px; font-weight:600;
  color:var(--ink); margin:0 0 6px;
}
.dash-empty p { margin:0; font-size:14px; }

/* ---------- ORDER CARDS ---------- */
.orders-list { display:flex; flex-direction:column; gap:12px; }

.order-card {
  background:#faf9f6; border:1px solid #e8e6e0;
  border-radius:14px; overflow:hidden;
  transition:all .2s ease;
}
.order-card:hover { border-color:#d8d4cc; }
.order-card.expanded { background:#fff; border-color:#d8d4cc; box-shadow:0 6px 20px -10px rgba(0,0,0,.1); }

.oc-head {
  display:grid;
  grid-template-columns:1.4fr 1fr auto 32px;
  gap:24px; align-items:center;
  padding:18px 22px; cursor:pointer;
}
.oc-id-main {
  font-family:'JetBrains Mono', monospace;
  font-weight:600; font-size:13.5px;
  color:var(--ink); letter-spacing:.3px;
}
.oc-id-date {
  font-size:12px; color:var(--muted);
  margin-top:3px;
}
.oc-summary { display:flex; gap:24px; align-items:center; }
.oc-sites {
  font-size:13.5px; color:var(--muted); font-weight:500;
}
.oc-total {
  font-family:'Fraunces',serif;
  font-size:20px; font-weight:600; color:var(--ink);
}
.oc-chev {
  color:var(--muted); transition:transform .25s ease;
}
.order-card.expanded .oc-chev { transform:rotate(180deg); }

/* Status badges */
.badge {
  display:inline-flex; align-items:center;
  padding:5px 11px; border-radius:999px;
  font-size:11.5px; font-weight:600;
  letter-spacing:.3px; white-space:nowrap;
}
.badge-pending      { background:#fef5e7; color:#a06200; }
.badge-invoice_sent { background:#fff4e6; color:#c25a00; }
.badge-paid         { background:#e7f5ee; color:#1f7a4d; }
.badge-in_progress  { background:#eef2ff; color:#2740a0; }
.badge-published    { background:#e0f7e9; color:#0e6b3d; }
.badge-completed    { background:#d8efe0; color:#0a5a30; }
.badge-cancelled    { background:#fde5e3; color:#9a2620; }
.badge-admin        { background:#ffe9dd; color:#c04200; margin-left:8px; font-size:10.5px; padding:3px 8px; }

/* Order body (expanded) */
.oc-body {
  padding:0 22px 22px;
  border-top:1px solid #f0eee8;
  animation:slideDown .25s ease;
}
@keyframes slideDown {
  from { opacity:0; transform:translateY(-6px); }
  to { opacity:1; transform:translateY(0); }
}

.oc-customer {
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:18px; padding:20px;
  background:#f8f7f4; border-radius:10px;
  margin-top:18px;
}
.oc-customer > div { font-size:14px; color:var(--ink); }
.oc-customer a { color:var(--accent); font-weight:500; text-decoration:none; }
.oc-customer a:hover { text-decoration:underline; }
.oc-lbl {
  display:block; font-size:11px; font-weight:600;
  color:var(--muted); text-transform:uppercase;
  letter-spacing:.5px; margin-bottom:4px;
}

.oc-section { margin-top:22px; }
.oc-section h5 {
  font-family:'Fraunces',serif;
  font-size:16px; font-weight:600;
  margin:0 0 14px; color:var(--ink);
}

.oc-sites-list {
  display:flex; flex-direction:column; gap:10px;
}
.oc-site-row {
  display:grid; grid-template-columns:1fr 1.2fr;
  gap:18px; padding:14px 16px;
  background:#fff; border:1px solid #e8e6e0;
  border-radius:10px; align-items:center;
}
.order-card.expanded .oc-site-row { background:#faf9f6; }
.oc-site-name {
  font-weight:600; font-size:14px; color:var(--ink);
  word-break:break-all;
}
.oc-site-meta {
  font-size:12.5px; color:var(--muted); margin-top:3px;
}
.oc-site-url {
  display:flex; gap:8px; align-items:center;
}
.oc-url-input {
  flex:1; padding:9px 12px;
  border:1px solid #e8e6e0; border-radius:8px;
  font-family:inherit; font-size:13px;
  background:#fff; color:var(--ink);
}
.oc-url-input:focus {
  outline:none; border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(255,91,30,.1);
}
.oc-url-save {
  padding:9px 16px; background:var(--accent); color:#fff;
  border:0; border-radius:8px; font-weight:600; font-size:13px;
  cursor:pointer; font-family:inherit;
  transition:background .15s ease;
}
.oc-url-save:hover { background:#e54a10; }
.oc-url-save:disabled { opacity:.5; cursor:not-allowed; }
.oc-url-live {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 14px; background:#e0f7e9; color:#0e6b3d;
  border-radius:8px; font-weight:600; font-size:13px;
  text-decoration:none;
}
.oc-url-live:hover { background:#cdedd9; }
.oc-url-pending {
  font-size:13px; color:var(--muted); font-style:italic;
}

.oc-details-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
  gap:14px; padding:16px;
  background:#f8f7f4; border-radius:10px;
}
.oc-details-grid > div { font-size:13.5px; color:var(--ink); }
.oc-detail-block {
  margin-top:14px; padding:14px 16px;
  background:#f8f7f4; border-radius:10px;
}
.oc-detail-block p { margin:4px 0 0; font-size:13.5px; color:var(--ink); line-height:1.55; white-space:pre-wrap; }
.oc-detail-block small { font-size:12px; color:var(--muted); }

/* Status update buttons */
.status-btns {
  display:flex; flex-wrap:wrap; gap:8px;
}
.status-btn {
  padding:8px 14px; background:#fff;
  border:1px solid #e8e6e0; border-radius:8px;
  font-family:inherit; font-size:12.5px; font-weight:500;
  color:var(--ink); cursor:pointer;
  transition:all .15s ease;
}
.status-btn:hover { border-color:#c8c4bc; background:#faf9f6; }
.status-btn.active {
  background:var(--accent); color:#fff; border-color:var(--accent);
  font-weight:600;
}

.admin-notes-ta {
  width:100%; padding:12px 14px;
  background:#fff; border:1px solid #e8e6e0;
  border-radius:10px; font-family:inherit;
  font-size:13.5px; color:var(--ink);
  min-height:80px; resize:vertical;
}
.admin-notes-ta:focus {
  outline:none; border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(255,91,30,.1);
}

/* ---------- ADMIN TABS ---------- */
.admin-tabs {
  display:flex; gap:6px; margin-bottom:18px;
  background:#fff; padding:5px; border-radius:12px;
  border:1px solid #e8e6e0; width:fit-content;
}
.admin-tab {
  padding:10px 22px; background:none; border:0;
  font-family:'Inter Tight',sans-serif;
  font-weight:600; font-size:14px; color:var(--muted);
  cursor:pointer; border-radius:8px;
  transition:all .15s ease;
}
.admin-tab.active {
  background:var(--accent); color:#fff;
}
.admin-tab:not(.active):hover { background:#faf9f6; color:var(--ink); }

/* ---------- USER CARDS (admin → users tab) ---------- */
.users-list { display:flex; flex-direction:column; gap:10px; }
.user-card {
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  gap:18px; align-items:center;
  padding:16px 20px;
  background:#faf9f6; border:1px solid #e8e6e0;
  border-radius:12px;
  transition:all .15s ease;
}
.user-card:hover { border-color:#d8d4cc; background:#fff; }
.user-avatar {
  width:44px; height:44px; border-radius:50%;
  background:linear-gradient(135deg, #ff5b1e, #ff7a3d);
  color:#fff; font-weight:700; font-size:18px;
  display:flex; align-items:center; justify-content:center;
}
.user-name {
  font-weight:600; font-size:15px; color:var(--ink);
  display:flex; align-items:center;
}
.user-email { font-size:13px; color:var(--muted); margin-top:2px; word-break:break-all; }
.user-phone { font-size:12.5px; color:var(--muted); margin-top:1px; }
.user-stats {
  display:flex; gap:24px;
  padding-right:14px; border-right:1px solid #e8e6e0;
}
.user-stats > div {
  text-align:center;
}
.user-stats b {
  display:block; font-family:'Fraunces',serif;
  font-size:18px; color:var(--ink);
}
.user-stats span {
  font-size:11px; color:var(--muted);
  text-transform:uppercase; letter-spacing:.4px;
}
.user-view-btn {
  padding:8px 14px; background:none;
  border:1px solid #e8e6e0; border-radius:8px;
  font-family:inherit; font-size:13px; font-weight:500;
  color:var(--ink); cursor:pointer;
  transition:all .15s ease;
}
.user-view-btn:hover { background:var(--accent); color:#fff; border-color:var(--accent); }

/* ---------- Logged-in pill (checkout) ---------- */
.logged-in-pill {
  display:flex; align-items:center; gap:10px;
  padding:12px 16px; margin-bottom:16px;
  background:#e7f5ee; color:#1f7a4d;
  border-radius:10px; font-size:13.5px;
  border:1px solid #cce8d8;
}
.logged-in-pill svg { flex-shrink:0; }
.logged-in-pill b { color:var(--ink); }

/* ---------- Responsive tweaks ---------- */
@media (max-width: 900px) {
  .nav-user-name { display:none; }
  .nav-dash span, .nav-admin span { display:none; }
  .dash-stats { grid-template-columns:repeat(2, 1fr); }
  .dash-h { font-size:32px; }
  .oc-head {
    grid-template-columns:1fr auto;
    gap:14px;
  }
  .oc-summary { grid-column:1 / -1; order:3; }
  .oc-customer { grid-template-columns:1fr; gap:12px; }
  .oc-site-row { grid-template-columns:1fr; gap:12px; }
  .user-card { grid-template-columns:auto 1fr; }
  .user-stats, .user-view-btn { grid-column:1 / -1; }
  .user-stats { border-right:0; padding-right:0; border-top:1px solid #e8e6e0; padding-top:12px; justify-content:flex-start; gap:32px; }
}
@media (max-width: 600px) {
  .nav-auth-out .nav-login,
  .nav-auth-out .nav-cta { font-size:13px; padding:8px 12px; }
  .dash-stats { grid-template-columns:1fr 1fr; }
  .dash-card { padding:20px 16px 24px; }
  .dash-card-head h3 { font-size:18px; }
  .auth-section { padding:40px 16px 60px; }
  .dash-section { padding:32px 12px 60px; }
}

/* =========================================================
   ============ V3 ADDITIONS ===============================
   ========================================================= */

/* ---------- LOGO: ensure transparent background look ---------- */
.nav, footer { /* keep existing colors */ }
.logo-img, .foot-logo-img { background:transparent; }

/* ---------- PACKAGES SECTION ---------- */
.packages-section {
  padding:80px 24px;
  background:linear-gradient(180deg, #faf9f6 0%, #fff 100%);
}
.packages-grid {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.packages-grid-full { padding:20px 24px 0; }

.pkg-card {
  background:#fff; border:1px solid #e8e6e0;
  border-radius:20px; padding:32px 28px 28px;
  position:relative; transition:all .25s ease;
  display:flex; flex-direction:column;
}
.pkg-card:hover { transform:translateY(-4px); box-shadow:0 24px 64px -28px rgba(0,0,0,.18); }

.pkg-card-highlight {
  border:2px solid var(--accent);
  background:linear-gradient(180deg, #fff 0%, #fff7f3 100%);
  transform:scale(1.02);
  box-shadow:0 20px 56px -24px rgba(255,91,30,.25);
}
.pkg-card-highlight:hover { transform:scale(1.02) translateY(-4px); }

.pkg-badge {
  position:absolute; top:-12px; left:50%;
  transform:translateX(-50%);
  background:linear-gradient(135deg, var(--accent), #ff7a3d);
  color:#fff; padding:6px 18px;
  border-radius:999px; font-size:11.5px;
  font-weight:700; letter-spacing:.5px;
  text-transform:uppercase;
  box-shadow:0 4px 14px rgba(255,91,30,.35);
}

.pkg-name {
  font-family:'Fraunces',serif;
  font-size:26px; font-weight:600;
  color:var(--ink); margin-bottom:6px;
  letter-spacing:-.4px;
}
.pkg-tagline {
  font-size:13.5px; color:var(--muted);
  margin-bottom:24px; line-height:1.5;
}
.pkg-price {
  display:flex; align-items:baseline; gap:10px;
  margin-bottom:28px; padding-bottom:24px;
  border-bottom:1px solid #f0eee8;
}
.pkg-price-amt {
  font-family:'Fraunces',serif;
  font-size:48px; font-weight:600;
  color:var(--ink); line-height:1; letter-spacing:-1.5px;
}
.pkg-price-lbl {
  font-size:13px; color:var(--muted);
}

.pkg-features {
  flex:1;
  display:flex; flex-direction:column; gap:14px;
  margin-bottom:28px;
}
.pkg-feature {
  display:flex; align-items:flex-start; gap:11px;
  font-size:14px; color:#3d3d3a; line-height:1.45;
}
.pkg-feature svg { color:var(--accent); flex-shrink:0; margin-top:2px; }
.pkg-feature b { color:var(--ink); font-weight:600; }
.pkg-tier-meta { color:var(--muted); font-size:12.5px; }
.pkg-total {
  padding-top:10px;
  border-top:1px dashed #e8e6e0;
  font-weight:600;
}

.pkg-tier-dot {
  width:10px; height:10px; border-radius:50%;
  margin-top:6px; flex-shrink:0;
}
.pkg-tier-best   { background:linear-gradient(135deg, #ffaa00, #ff5b1e); }
.pkg-tier-normal { background:linear-gradient(135deg, #4f8cff, #2740a0); }
.pkg-tier-low    { background:linear-gradient(135deg, #c8c4bc, #908b80); }

.pkg-cta {
  width:100%; padding:14px;
  background:#fff; border:1.5px solid var(--ink);
  color:var(--ink); border-radius:11px;
  font-family:'Inter Tight',sans-serif;
  font-weight:600; font-size:14.5px;
  cursor:pointer; display:flex; align-items:center;
  justify-content:center; gap:8px;
  transition:all .15s ease;
}
.pkg-cta:hover { background:var(--ink); color:#fff; }
.pkg-cta-primary {
  background:var(--accent);
  border-color:var(--accent); color:#fff;
}
.pkg-cta-primary:hover { background:#e54a10; border-color:#e54a10; }

.packages-cta {
  text-align:center; margin-top:48px;
}

/* Customized section */
.customized-section {
  padding:60px 24px 100px; max-width:1100px; margin:0 auto;
}
.customized-card {
  background:#fff; border:1px solid #e8e6e0;
  border-radius:18px; padding:40px;
  display:flex; align-items:center; justify-content:space-between;
  gap:32px; flex-wrap:wrap;
}
.customized-info {
  flex:1; min-width:280px;
  display:flex; flex-direction:column; gap:12px;
}
.customized-feature {
  display:flex; align-items:center; gap:11px;
  font-size:14.5px; color:#3d3d3a;
}
.customized-feature svg { color:var(--accent); flex-shrink:0; }

@media (max-width: 900px) {
  .packages-grid { grid-template-columns:1fr; max-width:480px; }
  .pkg-card-highlight { transform:none; }
  .pkg-card-highlight:hover { transform:translateY(-4px); }
  .customized-card { flex-direction:column; align-items:stretch; padding:28px 24px; }
}

/* ---------- GOOGLE AUTH BUTTON ---------- */
.btn-google {
  width:100%; padding:12px;
  background:#fff; border:1.5px solid #e8e6e0;
  border-radius:10px; font-family:inherit;
  font-weight:600; font-size:14.5px; color:var(--ink);
  cursor:pointer; display:flex; align-items:center;
  justify-content:center; gap:11px;
  transition:all .15s ease;
  margin-bottom:18px;
}
.btn-google:hover { border-color:#c8c4bc; background:#faf9f6; box-shadow:0 2px 8px rgba(0,0,0,.04); }
.btn-google svg { flex-shrink:0; }

.auth-divider {
  position:relative; text-align:center;
  margin:18px 0 22px; color:var(--muted);
  font-size:12px; letter-spacing:.4px;
  text-transform:uppercase;
}
.auth-divider::before {
  content:''; position:absolute; top:50%; left:0; right:0;
  height:1px; background:#e8e6e0; z-index:0;
}
.auth-divider span {
  position:relative; background:#fff; padding:0 14px;
  z-index:1;
}

/* ---------- REFERENCE CODE BOX (success modal) ---------- */
.ref-code-box {
  background:linear-gradient(135deg, #fff7f3 0%, #fff 100%);
  border:2px dashed var(--accent);
  border-radius:14px; padding:22px 24px;
  margin:24px 0 20px;
  text-align:center;
}
.ref-code-label {
  font-size:12px; font-weight:600;
  color:var(--accent); text-transform:uppercase;
  letter-spacing:.6px; margin-bottom:8px;
}
.ref-code-value {
  font-family:'JetBrains Mono', monospace;
  font-size:28px; font-weight:700;
  color:var(--ink); letter-spacing:1px;
  margin-bottom:12px;
}
.ref-code-copy {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px; background:#fff;
  border:1px solid #e8e6e0; border-radius:8px;
  font-family:inherit; font-weight:600; font-size:12.5px;
  color:var(--ink); cursor:pointer;
  transition:all .15s ease;
}
.ref-code-copy:hover { border-color:var(--accent); color:var(--accent); }
.ref-code-note {
  font-size:12.5px; color:var(--muted);
  margin-top:10px;
}

.ref-code-mini {
  display:flex; align-items:center; gap:10px;
  padding:14px 16px; background:#fff7f3;
  border:1px solid #ffd9c4; border-radius:10px;
  margin-bottom:18px;
}
.ref-code-mini code {
  font-family:'JetBrains Mono', monospace;
  font-weight:600; color:var(--accent); font-size:14px;
}

/* ---------- PAYMENT DETAILS BOX (success) ---------- */
.payment-box {
  background:#f8f7f4; border:1px solid #e8e6e0;
  border-radius:14px; padding:22px 24px;
  margin-bottom:20px; text-align:left;
}
.payment-box h4 {
  font-family:'Fraunces',serif;
  font-size:17px; font-weight:600;
  margin:0 0 16px; color:var(--ink);
}
.payment-grid {
  display:grid; grid-template-columns:repeat(2, 1fr);
  gap:14px;
}
.payment-grid > div { font-size:14px; color:var(--ink); word-break:break-all; }
.payment-grid code {
  font-family:'JetBrains Mono', monospace;
  font-weight:600; font-size:13.5px;
  background:#fff; padding:3px 8px;
  border:1px solid #e8e6e0; border-radius:5px;
  color:var(--ink);
}
.payment-bank {
  margin-top:14px; padding-top:14px;
  border-top:1px solid #e8e6e0;
}
.payment-bank p {
  margin:4px 0 0; font-size:13.5px;
  color:var(--ink); line-height:1.55;
}
.payment-extra {
  margin-top:14px; padding:12px 14px;
  background:#fff7f3; border-radius:8px;
  font-size:13.5px; color:#3d3d3a;
  line-height:1.6; white-space:pre-wrap;
}

@media (max-width: 600px) {
  .payment-grid { grid-template-columns:1fr; }
}

/* ---------- ORDER CARD: refCode / package / approve ---------- */
.oc-ref {
  font-family:'JetBrains Mono', monospace;
  font-weight:600; color:var(--accent);
}
.oc-pkg {
  font-weight:600; color:var(--ink);
  padding:1px 7px; background:#fff7f3;
  border-radius:5px; font-size:11px;
}
.oc-head { grid-template-columns:1.4fr 1fr auto auto 32px !important; }
.oc-approve-btn {
  display:inline-flex; align-items:center; gap:5px;
  padding:7px 13px; background:#e0f7e9;
  border:1px solid #b8e6c8; border-radius:8px;
  color:#0e6b3d; font-weight:600; font-size:12.5px;
  cursor:pointer; font-family:inherit;
  transition:all .15s ease;
}
.oc-approve-btn:hover {
  background:#cdedd9; border-color:#90d4a8;
}

.btn-approve-all {
  display:inline-flex; align-items:center; gap:6px;
  padding:9px 14px;
  background:linear-gradient(135deg, #1f7a4d, #2da069);
  color:#fff; border:0; border-radius:9px;
  font-family:inherit; font-weight:600; font-size:13px;
  cursor:pointer; transition:all .15s ease;
}
.btn-approve-all:hover {
  background:linear-gradient(135deg, #176338, #1f8458);
  box-shadow:0 4px 14px rgba(31,122,77,.3);
}

/* ---------- ADMIN: SITES & PRICES TAB ---------- */
.admin-help {
  font-size:13.5px; color:var(--muted);
  margin:-8px 0 18px; line-height:1.55;
}
.admin-sites-list {
  display:flex; flex-direction:column; gap:8px;
}
.adm-site-row {
  display:grid;
  grid-template-columns:1.2fr 2fr auto;
  gap:16px; align-items:center;
  padding:14px 18px;
  background:#faf9f6; border:1px solid #e8e6e0;
  border-radius:11px;
  transition:all .15s ease;
}
.adm-site-row:hover { border-color:#d8d4cc; background:#fff; }
.adm-site-hidden { opacity:.55; }

.adm-site-name {
  font-weight:600; font-size:14px;
  color:var(--ink); word-break:break-all;
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
}
.adm-site-meta {
  font-size:12.5px; color:var(--muted); margin-top:3px;
  display:flex; align-items:center; gap:8px;
}
.adm-site-tag {
  display:inline-block;
  padding:2px 7px; background:var(--accent); color:#fff;
  border-radius:4px; font-size:10px; font-weight:700;
  text-transform:uppercase; letter-spacing:.4px;
}
.adm-site-tag-hidden { background:#888; }

.tier-pill {
  display:inline-block;
  padding:2px 9px; border-radius:5px;
  font-size:11px; font-weight:600;
}
.tier-best   { background:#fff1e0; color:#b85a00; }
.tier-normal { background:#e6efff; color:#2740a0; }
.tier-low    { background:#ebe9e3; color:#5c5950; }

.adm-site-fields {
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:8px;
}
.adm-mini-field {
  display:flex; flex-direction:column; gap:3px;
}
.adm-mini-field span {
  font-size:10.5px; font-weight:600;
  color:var(--muted); text-transform:uppercase;
  letter-spacing:.4px;
}
.adm-mini-field input {
  padding:7px 10px; background:#fff;
  border:1px solid #e8e6e0; border-radius:7px;
  font-family:inherit; font-size:13px;
}
.adm-mini-field input:focus {
  outline:none; border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(255,91,30,.1);
}

.adm-site-actions { display:flex; gap:6px; }
.adm-site-save, .adm-site-toggle, .adm-site-delete {
  padding:8px 12px; border:0;
  border-radius:7px; font-family:inherit;
  font-weight:600; font-size:12.5px;
  cursor:pointer; transition:all .15s ease;
}
.adm-site-save { background:var(--accent); color:#fff; }
.adm-site-save:hover { background:#e54a10; }
.adm-site-toggle { background:#fff; border:1px solid #e8e6e0; color:var(--ink); }
.adm-site-toggle:hover { background:#faf9f6; }
.adm-site-delete { background:#fff; border:1px solid #fde5e3; color:#9a2620; }
.adm-site-delete:hover { background:#fde5e3; }

.admin-pagination {
  display:flex; justify-content:center; align-items:center;
  gap:14px; margin-top:18px;
  font-size:13px; color:var(--muted);
}
.admin-pagination button {
  padding:8px 16px; background:#fff;
  border:1px solid #e8e6e0; border-radius:8px;
  font-family:inherit; font-weight:500; font-size:13px;
  color:var(--ink); cursor:pointer;
  transition:all .15s ease;
}
.admin-pagination button:hover:not(:disabled) { background:#faf9f6; border-color:#c8c4bc; }
.admin-pagination button:disabled { opacity:.4; cursor:not-allowed; }

/* ---------- ADMIN: FORMS ---------- */
.admin-form { padding:8px 0; }
.admin-form-row {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:16px; margin-bottom:6px;
}
.admin-form .auth-field { margin-bottom:18px; }
.hint { font-size:12.5px; color:var(--muted); margin-top:4px; line-height:1.45; }

/* ---------- IMPORT TAB ---------- */
.import-tabs {
  display:flex; gap:6px;
  background:#f5f4f0; padding:5px;
  border-radius:10px; margin-bottom:18px;
  width:fit-content;
}
.import-tab {
  padding:9px 18px; background:none; border:0;
  font-family:'Inter Tight',sans-serif;
  font-weight:600; font-size:13.5px; color:var(--muted);
  cursor:pointer; border-radius:7px;
  transition:all .15s ease;
}
.import-tab.active { background:#fff; color:var(--ink); }

.file-drop {
  display:flex; flex-direction:column; align-items:center;
  gap:8px; padding:36px 24px;
  background:#faf9f6; border:2px dashed #d8d4cc;
  border-radius:12px; cursor:pointer;
  transition:all .15s ease; text-align:center;
}
.file-drop:hover { background:#f5f4f0; border-color:var(--accent); }
.file-drop svg { color:var(--accent); }
.file-drop strong { font-size:15px; color:var(--ink); font-weight:600; }
.file-drop span { font-size:13px; color:var(--muted); }

.import-meta {
  background:#fff7f3; padding:14px 18px;
  border-radius:10px; font-size:13.5px;
  color:var(--ink); line-height:1.6;
  margin-bottom:18px; border:1px solid #ffd9c4;
}
.import-meta code {
  background:#fff; padding:2px 7px; border-radius:4px;
  font-family:'JetBrains Mono', monospace; font-size:12px;
  color:var(--accent); font-weight:600;
}
.import-meta b { color:var(--accent); }

.import-preview { overflow-x:auto; }
.import-table {
  width:100%; border-collapse:collapse;
  background:#fff; border:1px solid #e8e6e0;
  border-radius:10px; overflow:hidden;
  font-size:13px;
}
.import-table th, .import-table td {
  padding:10px 14px; text-align:left;
  border-bottom:1px solid #f0eee8;
}
.import-table thead th {
  background:#faf9f6;
  font-weight:600; font-size:12px;
  text-transform:uppercase; letter-spacing:.4px;
  color:var(--muted);
}
.import-table tbody tr:last-child td { border-bottom:0; }
.import-more {
  text-align:center; padding:12px;
  color:var(--muted); font-size:13px;
  font-style:italic; margin:0;
}

.import-actions {
  display:flex; justify-content:flex-end;
  gap:10px; margin-top:18px;
}

/* ---------- HOME: badge-style packages section ---------- */
.packages-section .section-head { padding-bottom:32px; }


/* ===========================================================
   ============ NEW ADDITIONS (niche + invoice + bulk) =======
   =========================================================== */

/* ---------- PACKAGE NICHE SELECTOR ---------- */
.pkg-niche {
  margin-bottom:16px;
  padding:12px 14px;
  background:#faf9f6;
  border:1px solid #e8e6e0;
  border-radius:10px;
}
.pkg-niche label {
  display:block;
  font-size:11.5px; font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.5px;
  margin-bottom:6px;
}
.pkg-niche-select {
  width:100%; padding:8px 11px;
  background:#fff; border:1px solid #e8e6e0;
  border-radius:7px; font-family:inherit;
  font-size:13.5px; font-weight:500;
  color:var(--ink); cursor:pointer;
}
.pkg-niche-select:focus {
  outline:none; border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(255,91,30,.12);
}
.pkg-card-highlight .pkg-niche {
  background:rgba(255,247,243,.6);
  border-color:#ffd9c4;
}

/* ---------- INVOICE-STYLE SUCCESS SCREEN ---------- */
.invoice {
  padding:36px 40px;
  background:#fff;
  color:var(--ink);
}
.inv-header {
  display:flex; justify-content:space-between; align-items:flex-start;
  padding-bottom:24px; margin-bottom:24px;
  border-bottom:2px solid var(--ink);
}
.inv-brand-name {
  font-family:'Fraunces',serif;
  font-size:28px; font-weight:600;
  letter-spacing:-.6px; color:var(--ink);
}
.inv-brand-tag {
  font-size:12.5px; color:var(--muted); margin-top:2px;
}
.inv-meta { text-align:right; }
.inv-tag {
  font-size:11px; font-weight:700;
  letter-spacing:2px; color:var(--accent);
}
.inv-id {
  font-family:'JetBrains Mono', monospace;
  font-size:16px; font-weight:600;
  color:var(--ink); margin-top:4px;
}
.inv-date {
  font-size:13px; color:var(--muted); margin-top:2px;
}

.inv-success {
  display:flex; align-items:center; gap:14px;
  padding:14px 18px; margin-bottom:24px;
  background:#e8f7ec;
  border:1px solid #b8e0c4;
  border-radius:11px;
  font-size:14px; color:#0e6b3d;
  line-height:1.5;
}
.inv-success-icon {
  flex-shrink:0;
  width:34px; height:34px;
  background:#1f7a4d; color:#fff;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}

.inv-parties {
  display:grid; grid-template-columns:1fr 1fr;
  gap:24px; margin-bottom:28px;
}
.inv-party-lbl {
  font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.6px;
  color:var(--muted); margin-bottom:6px;
}
.inv-party-name {
  font-size:15px; font-weight:600;
  color:var(--ink); margin-bottom:4px;
}
.inv-party-detail {
  font-size:13px; color:#3d3d3a;
  line-height:1.5;
}

.inv-items-wrap { margin:24px 0; }
.inv-section-h {
  font-family:'Fraunces',serif;
  font-size:18px; font-weight:600; color:var(--ink);
  margin:0 0 12px;
  display:flex; align-items:baseline; justify-content:space-between;
}
.inv-count {
  font-family:'Inter Tight',sans-serif;
  font-size:12.5px; font-weight:500;
  color:var(--muted);
}

.inv-table {
  width:100%; border-collapse:collapse;
  font-size:13.5px;
}
.inv-table thead th {
  text-align:left; padding:10px 12px;
  font-size:11.5px; font-weight:700;
  text-transform:uppercase; letter-spacing:.5px;
  color:var(--muted);
  border-bottom:1.5px solid var(--ink);
}
.inv-row td {
  padding:11px 12px;
  border-bottom:1px solid #f0eee8;
  vertical-align:top;
}
.inv-site-name {
  font-weight:600; color:var(--ink);
  font-size:14px; margin-bottom:2px;
  word-break:break-all;
}
.inv-site-meta { font-size:12px; color:var(--muted); }
.inv-amt {
  text-align:right; font-weight:600;
  color:var(--ink); width:120px; min-width:120px;
  font-family:'JetBrains Mono', monospace;
}
.inv-table tfoot td {
  padding:10px 12px;
  font-size:14px; color:var(--ink);
}
.inv-table tfoot td:last-child {
  font-family:'JetBrains Mono', monospace;
  font-weight:600;
}
.inv-total td {
  border-top:2px solid var(--ink);
  font-size:17px !important;
  font-weight:700;
  padding-top:14px !important;
  color:var(--accent) !important;
}

.inv-email-box {
  display:flex; gap:14px; align-items:flex-start;
  background:#fff7f3;
  border:1px solid #ffd9c4;
  border-radius:12px;
  padding:18px 22px;
  margin-top:22px;
}
.inv-email-icon {
  flex-shrink:0; width:36px; height:36px;
  background:var(--accent); color:#fff;
  border-radius:9px;
  display:flex; align-items:center; justify-content:center;
}
.inv-email-body {
  display:flex; flex-direction:column; gap:4px;
  font-size:14px; line-height:1.5; color:var(--ink);
}
.inv-email-body strong { font-weight:600; }
.inv-email-body a {
  color:var(--accent); text-decoration:none;
  font-weight:600; border-bottom:1px solid var(--accent);
}
.inv-email-body span { font-size:13px; color:#3d3d3a; }
.inv-email-body code {
  background:#fff; padding:1px 7px;
  border:1px solid #ffd9c4; border-radius:4px;
  font-family:'JetBrains Mono', monospace;
  font-size:12.5px; color:var(--accent);
  font-weight:600;
}

.inv-actions {
  display:flex; gap:10px; justify-content:flex-end;
  margin-top:28px; padding-top:24px;
  border-top:1px solid #f0eee8;
  flex-wrap:wrap;
}
.inv-actions .btn-primary,
.inv-actions .btn-secondary {
  display:inline-flex; align-items:center; gap:7px;
  text-decoration:none;
}

@media (max-width: 700px) {
  .invoice { padding:24px 22px; }
  .inv-header { flex-direction:column; gap:16px; align-items:flex-start; }
  .inv-meta { text-align:left; }
  .inv-parties { grid-template-columns:1fr; gap:16px; }
  .inv-actions { justify-content:stretch; }
  .inv-actions > * { flex:1; justify-content:center; }
}

/* Print: clean invoice */
@media print {
  body * { visibility:hidden; }
  .modal-bg, .modal-bg * { visibility:visible; }
  .modal-bg { position:absolute; left:0; top:0; background:#fff; padding:0; }
  .modal { box-shadow:none; max-width:none; width:100%; }
  .modal-close, .inv-actions { display:none !important; }
}

/* ---------- BULK PRICE ACTIONS (admin) ---------- */
.bulk-actions {
  background:#faf9f6;
  border:1px solid #e8e6e0;
  border-radius:12px;
  padding:18px 20px;
  margin-bottom:20px;
}
.bulk-row {
  display:flex; align-items:center; gap:14px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.bulk-row:last-of-type { margin-bottom:0; }
.bulk-label {
  font-size:13px; font-weight:600;
  color:var(--ink);
}
.bulk-label em {
  font-style:normal; font-weight:500;
  color:var(--muted); font-size:12.5px;
}
.bulk-group {
  display:flex; align-items:center; gap:7px;
  background:#fff;
  border:1px solid #e8e6e0;
  border-radius:9px;
  padding:5px 8px 5px 12px;
}
.bulk-group label {
  font-size:12.5px; font-weight:600;
  color:var(--muted); white-space:nowrap;
}
.bulk-group input {
  width:130px; padding:6px 10px;
  background:transparent; border:0;
  font-family:inherit; font-size:13px;
  font-weight:500; color:var(--ink);
}
.bulk-group input:focus { outline:none; }
.bulk-suffix {
  font-size:13.5px; color:var(--muted);
  margin-left:-4px; margin-right:2px;
}
.bulk-btn {
  padding:6px 13px;
  background:var(--ink); color:#fff;
  border:0; border-radius:6px;
  font-family:inherit; font-weight:600; font-size:12.5px;
  cursor:pointer; transition:all .15s ease;
}
.bulk-btn:hover { background:var(--accent); }
.bulk-hint {
  font-size:12.5px; color:var(--muted);
  margin-top:8px;
}

@media (max-width: 700px) {
  .bulk-row { flex-direction:column; align-items:stretch; }
  .bulk-group { width:100%; justify-content:space-between; }
  .bulk-group input { flex:1; width:auto; }
}

/* Email field hint for the contact email in settings */
.contact-email-hint code {
  background:#fff7f3; padding:2px 8px;
  border:1px solid #ffd9c4; border-radius:4px;
  font-family:'JetBrains Mono', monospace;
  font-size:12.5px; color:var(--accent);
  font-weight:600;
}

/* Background-save failure warning on invoice */
.inv-save-warn {
  margin-top:20px; padding:14px 18px;
  background:#fff7e6; border:1px solid #ffd591;
  border-radius:10px; font-size:13.5px;
  color:#8c5a00; line-height:1.55;
}
.inv-save-warn a { color:#c46a00; font-weight:600; text-decoration:underline; }
.inv-save-warn code {
  background:#fff; padding:2px 7px;
  border:1px solid #ffd591; border-radius:4px;
  font-family:'JetBrains Mono', monospace;
  font-weight:600; color:#8c5a00; font-size:12.5px;
}

/* ===========================================================
   PACKAGE TIER ROWS (no site reveal)
   =========================================================== */
.cart-tier-row .ci-name {
  font-family:'Fraunces',serif;
  font-size:16px; font-weight:600;
}
.cart-tier-row .ci-meta {
  font-size:12.5px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.4px;
}

/* Customer order card: tier summary rows */
.oc-tier-row {
  background:#faf9f6;
  border-radius:9px; padding:12px 14px;
  margin-bottom:6px;
}
.oc-tier-row .oc-site-name {
  font-family:'Fraunces',serif;
  font-weight:600; font-size:14.5px;
}

/* Customer order card: published links block */
.oc-published-block {
  margin-top:16px; padding:16px 18px;
  background:#fff7f3; border:1px solid #ffd9c4;
  border-radius:10px;
}
.oc-published-block h6 {
  margin:0 0 10px;
  font-family:'Fraunces',serif;
  font-size:14px; font-weight:600;
  color:var(--ink);
}
.oc-published-list {
  display:flex; flex-direction:column; gap:6px;
}
.oc-url-live-row {
  display:flex; align-items:center; gap:8px;
  padding:8px 12px;
  background:#fff; border:1px solid #ffd9c4;
  border-radius:7px;
  color:var(--accent); font-size:13px;
  font-weight:500; text-decoration:none;
  word-break:break-all;
  transition:all .15s ease;
}
.oc-url-live-row:hover {
  background:#fff7f3;
  border-color:var(--accent);
}

.oc-pending-msg {
  display:flex; align-items:center; gap:10px;
  font-size:13px; color:var(--ink);
  line-height:1.5;
  background:#f0f4ff !important;
  border-color:#cdd6f0 !important;
}
.oc-pending-msg svg {
  color:#2740a0; flex-shrink:0;
}

/* Admin order card: small tier tag next to placement name */
.oc-tier-tag {
  display:inline-block;
  margin-left:6px;
  padding:1px 7px;
  background:#fff7f3;
  border:1px solid #ffd9c4;
  border-radius:4px;
  font-size:10.5px; font-weight:600;
  letter-spacing:.3px;
  color:var(--accent);
  font-family:'Inter Tight',sans-serif;
}

/* ===========================================================
   GHL-STYLE ADMIN DASHBOARD WITH LEFT SIDEBAR
   =========================================================== */

/* Override the page default for admin (no max-width constraint) */
#page-admin {
  padding:0;
  background:#f7f6f3;
  min-height:100vh;
}

.admin-layout {
  display:grid;
  grid-template-columns:260px 1fr;
  min-height:100vh;
}

/* ---------- LEFT SIDEBAR ---------- */
.admin-sidebar {
  background:#1c1c1a;
  color:#d8d4cc;
  display:flex; flex-direction:column;
  padding:24px 0 12px;
  position:sticky; top:0; height:100vh;
  overflow-y:auto;
  border-right:1px solid #2a2a27;
}

.sb-brand {
  display:flex; align-items:center; gap:12px;
  padding:0 22px 24px;
  border-bottom:1px solid #2a2a27;
  margin-bottom:18px;
}
.sb-brand-icon {
  width:42px; height:42px; border-radius:10px;
  background:linear-gradient(135deg, #ff7a3d, #ff5b1e);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-family:'Fraunces',serif;
  font-weight:700; font-size:22px;
  letter-spacing:-1px;
  box-shadow:0 4px 12px rgba(255,91,30,.35);
}
.sb-brand-name {
  font-family:'Fraunces',serif;
  font-size:17px; font-weight:600;
  color:#fff; letter-spacing:-.3px;
}
.sb-brand-sub {
  font-size:11.5px; color:#8e8a82;
  letter-spacing:.5px; text-transform:uppercase;
  margin-top:1px;
}

/* Sidebar mini stats */
.sb-stats {
  display:flex; flex-direction:column; gap:8px;
  padding:0 16px 20px;
  border-bottom:1px solid #2a2a27;
  margin-bottom:14px;
}
.sb-stat {
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 12px;
  background:#252522;
  border-radius:8px;
  font-size:12px;
}
.sb-stat span { color:#8e8a82; }
.sb-stat b {
  font-family:'JetBrains Mono', monospace;
  color:#fff; font-size:13.5px; font-weight:600;
}
.sb-stat-warn { color:#ffaa00 !important; }

/* Nav sections */
.sb-nav { flex:1; padding:0 12px; }
.sb-section { margin-bottom:18px; }
.sb-section-title {
  font-size:10.5px; font-weight:600;
  text-transform:uppercase; letter-spacing:.8px;
  color:#6a6760;
  padding:8px 12px 6px;
}
.sb-link {
  display:flex; align-items:center; gap:10px;
  width:100%; padding:10px 12px;
  background:transparent;
  border:0; border-radius:8px;
  color:#bdb8af; font-family:inherit;
  font-size:13.5px; font-weight:500;
  cursor:pointer; text-align:left;
  margin-bottom:2px;
  transition:all .15s ease;
}
.sb-link:hover { background:#252522; color:#fff; }
.sb-link.active {
  background:linear-gradient(90deg, rgba(255,91,30,.18), transparent);
  color:#fff;
  box-shadow:inset 3px 0 0 var(--accent);
}
.sb-link svg { flex-shrink:0; opacity:.8; }
.sb-link.active svg { opacity:1; color:var(--accent); }

.sb-badge {
  margin-left:auto;
  padding:2px 8px;
  background:#3a3a36;
  color:#fff; border-radius:99px;
  font-size:11px; font-weight:600;
  font-family:'JetBrains Mono', monospace;
}
.sb-link.active .sb-badge,
.sb-link:hover .sb-badge {
  background:var(--accent);
}

.sb-footer {
  padding:14px 12px 0;
  border-top:1px solid #2a2a27;
  margin-top:auto;
}
.sb-link-back { color:#6a6760; font-size:12.5px; }

/* ---------- MAIN CONTENT AREA ---------- */
.admin-main {
  padding:32px 36px 60px;
  background:#f7f6f3;
  min-height:100vh;
  max-width:none;
}

.admin-topbar {
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:24px; padding-bottom:18px;
  border-bottom:1px solid #e8e6e0;
}
.admin-page-title {
  font-family:'Fraunces',serif;
  font-size:30px; font-weight:600;
  color:var(--ink); margin:0 0 4px;
  letter-spacing:-.6px;
}
.admin-page-sub {
  font-size:14px; color:var(--muted); margin:0;
}

/* ---------- OVERVIEW PANE ---------- */
.overview-stats {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
}
.ov-stat {
  padding:22px 24px;
  background:#fff;
  border:1px solid #e8e6e0;
  border-radius:14px;
  position:relative; overflow:hidden;
}
.ov-stat::before {
  content:''; position:absolute;
  top:0; left:0; right:0; height:3px;
}
.ov-stat-blue::before   { background:linear-gradient(90deg, #4f8cff, #2740a0); }
.ov-stat-green::before  { background:linear-gradient(90deg, #2da069, #1f7a4d); }
.ov-stat-orange::before { background:linear-gradient(90deg, #ffaa00, #ff5b1e); }
.ov-stat-purple::before { background:linear-gradient(90deg, #a350c5, #6d2090); }

.ov-stat-lbl {
  font-size:12px; font-weight:600;
  color:var(--muted); text-transform:uppercase;
  letter-spacing:.5px; margin-bottom:8px;
}
.ov-stat-num {
  font-family:'Fraunces',serif;
  font-size:34px; font-weight:600;
  color:var(--ink); letter-spacing:-1px;
  line-height:1;
}

.overview-shortcuts {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:14px; margin-top:28px;
}
.ov-shortcut {
  display:flex; align-items:center; gap:14px;
  padding:18px 20px;
  background:#fff; border:1px solid #e8e6e0;
  border-radius:12px; cursor:pointer;
  text-align:left; font-family:inherit;
  transition:all .15s ease;
}
.ov-shortcut:hover {
  border-color:var(--accent);
  box-shadow:0 6px 22px -10px rgba(255,91,30,.25);
  transform:translateY(-2px);
}
.ov-sc-icon {
  width:42px; height:42px; flex-shrink:0;
  background:#fff7f3; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px;
}
.ov-sc-title {
  font-weight:600; font-size:14px; color:var(--ink);
  margin-bottom:2px;
}
.ov-sc-sub {
  font-size:12.5px; color:var(--muted);
}

/* ---------- PRIORITY SITE STAR ---------- */
.priority-star {
  display:inline-block;
  color:#ffaa00;
  font-size:14px;
  margin-left:4px;
  text-shadow:0 0 6px rgba(255,170,0,.4);
}
.site-priority {
  background:linear-gradient(90deg, #fffcf5 0%, transparent 60%);
}
.site-priority .domain {
  font-weight:600;
}

/* Admin sites list — priority highlight */
.adm-site-row[data-site*="."] .adm-site-tag {
  /* generic */
}

/* ---------- RESPONSIVE: collapse sidebar on small screens ---------- */
@media (max-width: 980px) {
  .admin-layout {
    grid-template-columns:1fr;
  }
  .admin-sidebar {
    position:relative;
    height:auto;
    flex-direction:row; flex-wrap:wrap;
    padding:16px;
    overflow:visible;
  }
  .sb-brand { padding:0 12px 16px; width:100%; }
  .sb-stats {
    flex-direction:row; padding:0 0 16px;
    border-bottom:0; width:100%;
  }
  .sb-stat { flex:1; }
  .sb-nav {
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:12px;
    padding:0;
  }
  .sb-section { margin-bottom:0; }
  .sb-footer { width:100%; }
  .admin-main { padding:24px 20px 40px; }
  .overview-stats { grid-template-columns:repeat(2, 1fr); }
  .admin-topbar { flex-direction:column; gap:12px; }
}
@media (max-width: 560px) {
  .sb-nav { grid-template-columns:1fr; }
  .sb-stats { flex-direction:column; }
  .overview-stats { grid-template-columns:1fr; }
}

/* ===========================================================
   PR CREDITS WIDGET (customer dashboard)
   =========================================================== */

.credits-widget {
  background:linear-gradient(135deg, #fffaf5 0%, #fff 70%);
  border:1px solid #ffd9c4;
  border-radius:14px;
  padding:22px 24px;
  margin-top:6px;
}

.credits-head {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:14px;
}
.credits-title {
  display:flex; align-items:center; gap:8px;
  font-family:'Fraunces',serif;
  font-size:18px; font-weight:600;
  color:var(--ink);
}
.credits-title svg { color:#ffaa00; }
.credits-counter {
  font-family:'JetBrains Mono', monospace;
  font-size:14px;
}
.credits-used {
  font-size:22px; font-weight:700;
  color:var(--accent);
}
.credits-divider { color:var(--muted); margin:0 2px; }
.credits-total { font-weight:600; color:var(--ink); }
.credits-lbl {
  font-family:'Inter Tight',sans-serif;
  font-size:11.5px; font-weight:500;
  color:var(--muted); margin-left:6px;
  text-transform:uppercase; letter-spacing:.4px;
}

.credits-bar {
  height:8px; background:#f0eee8;
  border-radius:99px; overflow:hidden;
  margin-bottom:18px;
}
.credits-bar-fill {
  height:100%;
  background:linear-gradient(90deg, var(--accent), #ff7a3d);
  border-radius:99px;
  transition:width .5s ease;
}

.credits-locked-msg {
  display:flex; align-items:flex-start; gap:10px;
  padding:12px 14px;
  background:#fff7e6;
  border:1px solid #ffd591;
  border-radius:10px;
  font-size:13px; color:#8c5a00; line-height:1.5;
  margin-bottom:16px;
}
.credits-locked-msg svg { flex-shrink:0; color:#c46a00; margin-top:2px; }

.credits-available-block,
.credits-progress-block,
.credits-published-block {
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid #f0eee8;
}
.credits-available-block h6,
.credits-progress-block h6,
.credits-published-block h6 {
  font-family:'Fraunces',serif;
  font-size:14.5px; font-weight:600;
  color:var(--ink); margin:0 0 10px;
}

.credits-tier-line {
  display:flex; justify-content:space-between; align-items:center;
  padding:11px 14px;
  background:#fff; border:1px solid #e8e6e0;
  border-radius:10px; margin-bottom:8px;
}
.credits-tier-info {
  display:flex; align-items:center; gap:10px;
  font-size:13.5px; color:#3d3d3a;
}
.credits-tier-info b { color:var(--ink); font-weight:600; }
.credits-tier-dot {
  width:10px; height:10px; border-radius:50%;
}
.credits-tier-best   { background:linear-gradient(135deg, #ffaa00, #ff5b1e); }
.credits-tier-normal { background:linear-gradient(135deg, #4f8cff, #2740a0); }
.credits-tier-low    { background:linear-gradient(135deg, #c8c4bc, #908b80); }

.use-credit-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px;
  background:var(--accent); color:#fff;
  border:0; border-radius:8px;
  font-family:inherit; font-weight:600; font-size:13px;
  cursor:pointer; transition:all .15s ease;
}
.use-credit-btn:hover {
  background:#e54a10;
  box-shadow:0 4px 14px rgba(255,91,30,.3);
  transform:translateY(-1px);
}

.credits-progress-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 14px;
  background:#f8f7f4; border-radius:9px;
  margin-bottom:6px;
}
.credits-progress-topic {
  font-weight:600; font-size:13.5px; color:var(--ink);
  margin-bottom:2px;
}
.credits-progress-meta { font-size:12px; color:var(--muted); }
.credits-progress-pill {
  padding:3px 9px;
  background:#fff7e6; color:#8c5a00;
  border:1px solid #ffd591; border-radius:5px;
  font-size:11px; font-weight:600;
  text-transform:uppercase; letter-spacing:.3px;
}

.credits-published-row {
  display:flex; align-items:center; gap:11px;
  padding:11px 14px;
  background:#fff; border:1px solid #ffd9c4;
  border-radius:10px;
  text-decoration:none;
  margin-bottom:6px;
  transition:all .15s ease;
}
.credits-published-row:hover {
  background:#fff7f3;
  border-color:var(--accent);
  transform:translateX(2px);
}
.credits-published-row svg { color:var(--accent); flex-shrink:0; }
.credits-pub-url {
  color:var(--accent); font-weight:600; font-size:13px;
  word-break:break-all;
}
.credits-pub-topic {
  color:var(--muted); font-size:12px; margin-top:2px;
}

/* Small status pills next to admin placement names */
.oc-status-mini {
  display:inline-block; margin-left:6px;
  padding:1px 7px; border-radius:4px;
  font-size:10.5px; font-weight:600;
  text-transform:uppercase; letter-spacing:.3px;
  font-family:'Inter Tight', sans-serif;
}
.oc-status-locked    { background:#f0eee8; color:#888; }
.oc-status-available { background:#e8f7ec; color:#1f7a4d; }
.oc-status-requested { background:#fff7e6; color:#8c5a00; }
.oc-status-in_progress { background:#e6efff; color:#2740a0; }
.oc-status-published { background:#fff7f3; color:var(--accent); }

/* ===========================================================
   CREDIT REQUESTS QUEUE (admin)
   =========================================================== */
.cr-card {
  background:#fff; border:1px solid #e8e6e0;
  border-radius:12px;
  margin-bottom:14px;
  overflow:hidden;
}
.cr-head {
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:14px;
  padding:16px 18px;
  background:#faf9f6;
  border-bottom:1px solid #e8e6e0;
}
.cr-customer {
  font-family:'Fraunces',serif;
  font-size:16px; font-weight:600;
  color:var(--ink);
}
.cr-email {
  font-family:'Inter Tight',sans-serif;
  font-size:12.5px; font-weight:500;
  color:var(--muted); margin-left:6px;
}
.cr-meta {
  font-size:12px; color:var(--muted);
  margin-top:3px;
  word-break:break-all;
}
.cr-meta code {
  background:#fff; padding:1px 7px;
  border:1px solid #e8e6e0; border-radius:4px;
  font-family:'JetBrains Mono', monospace;
  color:var(--accent); font-weight:600;
}
.cr-tier {
  padding:5px 12px;
  border-radius:6px;
  font-size:12px; font-weight:700;
  white-space:nowrap;
}

.cr-body {
  padding:16px 18px;
}
.cr-field { margin-bottom:12px; }
.cr-field p {
  margin:3px 0 0;
  font-size:13.5px; color:var(--ink); line-height:1.5;
  word-break:break-word;
}
.cr-field a { color:var(--accent); text-decoration:none; font-weight:500; }
.cr-field a:hover { text-decoration:underline; }
.cr-field-row {
  display:grid; grid-template-columns:1fr 1.5fr;
  gap:18px; margin-bottom:12px;
}
.cr-publish {
  display:flex; gap:8px; align-items:stretch;
  margin-top:14px; padding-top:14px;
  border-top:1px dashed #e8e6e0;
}
.cr-publish input {
  flex:1; padding:9px 12px;
  border:1px solid #e8e6e0; border-radius:8px;
  font-family:'JetBrains Mono', monospace;
  font-size:13px;
}
.cr-publish input:focus {
  outline:none; border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(255,91,30,.1);
}

@media (max-width: 700px) {
  .cr-head { flex-direction:column; }
  .cr-field-row { grid-template-columns:1fr; }
  .cr-publish { flex-direction:column; }
}

/* ===========================================================
   USER DASHBOARD — GHL-STYLE SIDEBAR (matching brand colors)
   =========================================================== */
#page-dashboard {
  padding:0;
  background:#faf9f6;
  min-height:100vh;
}

.user-layout {
  display:grid;
  grid-template-columns:240px 1fr;
  min-height:100vh;
}

.user-sidebar {
  background:linear-gradient(180deg, #fff 0%, #fff7f3 100%);
  border-right:1px solid #ffd9c4;
  display:flex; flex-direction:column;
  padding:24px 0 12px;
  position:sticky; top:0; height:100vh;
  overflow-y:auto;
}

.usb-brand {
  display:flex; align-items:center; gap:11px;
  padding:0 20px 20px;
  border-bottom:1px solid #ffd9c4;
  margin-bottom:18px;
}
.usb-brand-icon {
  width:38px; height:38px; border-radius:10px;
  background:linear-gradient(135deg, #ff7a3d, #ff5b1e);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-family:'Fraunces',serif;
  font-weight:700; font-size:20px;
  box-shadow:0 4px 12px rgba(255,91,30,.3);
}
.usb-brand-name {
  font-family:'Fraunces',serif;
  font-size:16px; font-weight:600;
  color:var(--ink); letter-spacing:-.2px;
}
.usb-brand-sub {
  font-size:11px; color:var(--muted);
  letter-spacing:.5px; text-transform:uppercase;
  margin-top:1px;
}

.usb-stats {
  display:flex; flex-direction:column; gap:7px;
  padding:0 14px 18px;
  border-bottom:1px solid #ffd9c4;
  margin-bottom:14px;
}
.usb-stat {
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 11px;
  background:#fff;
  border:1px solid #e8e6e0;
  border-radius:8px;
  font-size:11.5px;
}
.usb-stat span { color:var(--muted); }
.usb-stat b {
  font-family:'JetBrains Mono', monospace;
  color:var(--ink); font-size:13.5px; font-weight:600;
}
.usb-stat-pos { color:#1f7a4d !important; }

.usb-nav { flex:1; padding:0 12px; }
.usb-section { margin-bottom:18px; }
.usb-section-title {
  font-size:10.5px; font-weight:700;
  text-transform:uppercase; letter-spacing:.8px;
  color:var(--muted);
  padding:8px 12px 6px;
}
.usb-link {
  display:flex; align-items:center; gap:10px;
  width:100%; padding:9px 12px;
  background:transparent;
  border:0; border-radius:8px;
  color:var(--ink); font-family:inherit;
  font-size:13.5px; font-weight:500;
  cursor:pointer; text-align:left;
  margin-bottom:2px;
  transition:all .15s ease;
}
.usb-link:hover { background:#fff7f3; }
.usb-link.active {
  background:var(--accent);
  color:#fff;
  box-shadow:0 4px 12px rgba(255,91,30,.25);
}
.usb-link svg { flex-shrink:0; opacity:.85; }

.usb-badge {
  margin-left:auto;
  padding:2px 8px;
  background:#fff7f3;
  color:var(--accent);
  border:1px solid #ffd9c4;
  border-radius:99px;
  font-size:11px; font-weight:700;
  font-family:'JetBrains Mono', monospace;
}
.usb-link.active .usb-badge {
  background:#fff;
  color:var(--accent);
  border-color:#fff;
}

.usb-footer {
  padding:12px 12px 0;
  border-top:1px solid #ffd9c4;
  margin-top:auto;
}
.usb-link-back { color:var(--muted); font-size:12.5px; }

.user-main {
  padding:32px 36px 60px;
  background:#faf9f6;
  min-height:100vh;
}
.user-topbar {
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:24px; padding-bottom:18px;
  border-bottom:1px solid #ffd9c4;
}
.user-page-title {
  font-family:'Fraunces',serif;
  font-size:28px; font-weight:600;
  color:var(--ink); margin:0 0 4px;
  letter-spacing:-.5px;
}
.user-page-sub {
  font-size:13.5px; color:var(--muted); margin:0;
}

.user-credit-block {
  padding:14px 16px;
  background:#faf9f6;
  border:1px solid #e8e6e0;
  border-radius:10px;
  margin-bottom:10px;
}
.user-credit-block-head {
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:10px;
  flex-wrap:wrap; gap:8px;
}
.ucb-pkg {
  font-family:'Fraunces',serif;
  font-weight:600; font-size:15px;
  color:var(--ink);
}
.ucb-meta {
  font-size:11.5px; color:var(--muted);
  margin-top:2px;
}
.ucb-meta code {
  background:#fff; padding:1px 6px;
  border:1px solid #e8e6e0; border-radius:4px;
  font-family:'JetBrains Mono', monospace;
  color:var(--accent); font-weight:600;
  font-size:11px;
}

@media (max-width: 980px) {
  .user-layout { grid-template-columns:1fr; }
  .user-sidebar {
    position:relative;
    height:auto;
    flex-direction:row; flex-wrap:wrap;
    padding:14px;
    overflow:visible;
  }
  .usb-brand { padding:0 12px 14px; width:100%; }
  .usb-stats {
    flex-direction:row; padding:0 0 14px;
    border-bottom:0; width:100%;
  }
  .usb-stat { flex:1; }
  .usb-nav {
    display:grid; grid-template-columns:repeat(2, 1fr);
    gap:10px; padding:0;
  }
  .usb-section { margin-bottom:0; }
  .usb-footer { width:100%; }
  .user-main { padding:22px 18px 40px; }
  .user-topbar { flex-direction:column; gap:12px; align-items:stretch; }
}
@media (max-width: 560px) {
  .usb-nav { grid-template-columns:1fr; }
  .usb-stats { flex-direction:column; }
}

/* ===========================================================
   DANGER ZONE (admin)
   =========================================================== */
.danger-zone {
  background:#fff5f5;
  border:1px solid #fca5a5;
  border-radius:12px;
  padding:20px 22px;
}
.danger-zone h4 {
  font-family:'Fraunces',serif;
  font-size:16px; font-weight:600;
  color:#9a2620; margin:0 0 6px;
}
.danger-zone p {
  font-size:13px; color:#7a1e19;
  margin:0 0 14px;
}
.danger-buttons {
  display:flex; gap:10px; flex-wrap:wrap;
}
.danger-btn {
  padding:10px 16px;
  background:#fff;
  border:1px solid #fca5a5;
  border-radius:8px;
  color:#9a2620; font-family:inherit;
  font-weight:600; font-size:13px;
  cursor:pointer; transition:all .15s ease;
}
.danger-btn:hover {
  background:#fee2e2;
  border-color:#dc2626;
  color:#7f1d1d;
}

/* Reset banner — eye-catching prompt to clean test data */
.reset-banner {
  display:flex; justify-content:space-between; align-items:center;
  gap:16px;
  padding:18px 22px;
  background:linear-gradient(135deg, #fff7e6 0%, #ffe9c9 100%);
  border:2px solid #ffaa00;
  border-radius:14px;
  margin-bottom:24px;
  box-shadow:0 4px 16px -6px rgba(255,170,0,.3);
}
.reset-banner-title {
  font-family:'Fraunces',serif;
  font-size:17px; font-weight:700;
  color:#8c5a00; margin-bottom:3px;
}
.reset-banner-sub {
  font-size:13.5px; color:#a07028;
}
.reset-banner-btn {
  padding:12px 22px;
  background:linear-gradient(135deg, #ff9500, #ff5b1e);
  border:0; border-radius:10px;
  color:#fff; font-family:inherit;
  font-weight:700; font-size:14px;
  cursor:pointer; white-space:nowrap;
  transition:all .15s ease;
  box-shadow:0 4px 14px rgba(255,91,30,.35);
}
.reset-banner-btn:hover {
  transform:translateY(-2px);
  box-shadow:0 6px 18px rgba(255,91,30,.45);
}

@media (max-width: 700px) {
  .reset-banner { flex-direction:column; align-items:stretch; text-align:center; }
}
