﻿*{box-sizing:border-box;margin:0;padding:0}
/* ── TYPOGRAPHY SYSTEM ── */
/* Sora: headlines, brands, numbers, CTAs */
/* Inter: body, labels, inputs */
/* Fraunces: decorative tagline only */
body{font-family:'Inter',sans-serif;font-size:14px;background:#f5f2ed;color:#111;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
button,input,select,textarea{font-family:'Inter',sans-serif}
.btn{font-family:'Sora',sans-serif;font-weight:600;letter-spacing:.01em}
.sec-label,.s-card-title,.color-section-title,.tab-btn,.plan-name,.a-page-title{font-family:'Sora',sans-serif}
.fg label,.tgl-label,.stat-lbl,.auth-sub,.nav-name,.a-nav-item{font-family:'Inter',sans-serif}
button{cursor:pointer}
.page{display:none}.page.active{display:block}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap;font-family:'Inter',sans-serif;padding:10px 18px;border:2px solid transparent;text-decoration:none}
.btn-primary{background:#c45c2a!important;color:#fff!important;border-color:#c45c2a!important;width:100%}
.btn-primary:hover{background:#a84d22!important;border-color:#a84d22!important;transform:translateY(-1px);box-shadow:0 4px 16px rgba(196,92,42,.35)}
.btn-dark{background:#111!important;color:#fff!important;border-color:#111!important}
.btn-dark:hover{background:#333!important;border-color:#333!important;transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.25)}
.btn-outline{background:#fff!important;color:#111!important;border-color:#3a3835!important}
.btn-outline:hover{background:#f0ece4!important;transform:translateY(-1px)}
.btn-danger{background:#fff!important;color:#c0392b!important;border-color:#c0392b!important;padding:7px 14px;font-size:12px}
.btn-danger:hover{background:#fdecea!important}
.btn-sm{background:#fff!important;color:#111!important;border:2px solid #3a3835!important;padding:6px 12px;font-size:12px;border-radius:6px;font-weight:700}
.btn-sm.red{color:#c0392b!important;border-color:#c0392b!important}
.btn-sm:hover{background:#f0ece4!important}
.btn-sm.red:hover{background:#fdecea!important}
.btn-dashed{width:100%;padding:10px;border:2px dashed #3a3835!important;border-radius:8px;background:#fff!important;color:#111!important;font-size:13px;font-weight:700}
.btn-dashed:hover{background:#f0ece4!important;border-color:#c45c2a!important;color:#c45c2a!important}
.btn-remove{width:100%;padding:7px;border:2px solid #c0392b!important;border-radius:8px;background:#fff!important;color:#c0392b!important;font-size:12px;font-weight:700;margin-top:6px}
.btn-remove:hover{background:#fdecea!important}

/* ── FORM ── */
.fg{margin-bottom:13px}
.fg label{display:block;font-size:11px;font-weight:700;color:#3a3835;margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}
.fg input,.fg select,.fg textarea{width:100%;padding:10px 12px;border:2px solid #c8c3bb;border-radius:8px;background:#fff;color:#111;font-size:13px;outline:none;transition:border-color .15s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:#c45c2a;box-shadow:0 0 0 3px rgba(196,92,42,.12);outline:none}
.form-error{font-size:12px;color:#c0392b;margin-bottom:10px;font-weight:700;padding:8px 10px;background:#fdecea;border-radius:6px;border:1px solid #f5aaaa}
.hint-box{font-family:'Inter',sans-serif;margin-top:14px;padding:10px 12px;background:#e8e4db;border:2px solid #c8c3bb;border-radius:8px;font-size:12px;color:#3a3835;text-align:center;font-weight:500}
.hint-box strong{color:#111}
.alink{color:#c45c2a;font-weight:700;cursor:pointer;text-decoration:underline}

/* ══ AUTH V2 — Dark Luxury ══ */
.auth-shell{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;background:#080604}
/* ─ Left panel ─ */
.auth-left{position:relative;padding:48px 52px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:#080604}
/* Copper decorative lines via pseudo-elements */
.auth-left::before{content:'';position:absolute;width:1.5px;height:62%;background:linear-gradient(180deg,transparent,rgba(196,92,42,.65),transparent);transform:rotate(-20deg);right:22%;top:10%;pointer-events:none;z-index:1}
.auth-left::after{content:'';position:absolute;width:1px;height:46%;background:linear-gradient(180deg,transparent,rgba(232,130,74,.38),transparent);transform:rotate(-20deg);right:29%;top:22%;pointer-events:none;z-index:1}
/* Abstract figure art */
.auth-fig-wrap{position:absolute;right:0;top:0;width:58%;height:100%;pointer-events:none;z-index:0}
.auth-fig-glow{position:absolute;right:-10%;top:50%;transform:translateY(-50%);width:100%;height:80%;background:radial-gradient(ellipse at 65% 42%,rgba(160,65,15,.22) 0%,rgba(100,35,5,.1) 35%,transparent 65%);border-radius:50%}
.auth-fig-shape{position:absolute;right:4%;top:6%;width:75%;height:88%;background:linear-gradient(165deg,rgba(170,70,15,.07) 0%,rgba(130,50,10,.13) 25%,rgba(80,28,4,.07) 55%,transparent 75%);border-radius:48% 52% 44% 56%/52% 44% 56% 48%;filter:blur(3px)}
.auth-fig-rim{position:absolute;right:2%;top:50%;transform:translateY(-50%);width:60%;height:75%;background:linear-gradient(90deg,transparent 0%,rgba(196,92,42,.04) 50%,rgba(232,130,74,.12) 100%);border-radius:50%}
/* Brand — absolutely positioned so it doesn't affect flex flow */
.auth-brand-block{position:absolute;top:25%;left:50%;transform:translate(-50%,-50%);z-index:3;width:85%;display:flex;align-items:center;justify-content:center}
.auth-monogram{font-family:'Fraunces',serif;font-size:44px;font-weight:300;color:#c45c2a;letter-spacing:4px;display:block;line-height:1;margin-bottom:8px}
.auth-brand-name{font-family:'Sora',sans-serif;font-size:10px;font-weight:700;color:rgba(255,255,255,.45);letter-spacing:.5em;text-transform:uppercase;display:block}
/* Logo image — 100% of brand-block (85% of left panel) */
.auth-logo-img{width:100%;max-width:100%;height:auto;display:block;filter:drop-shadow(0 0 28px rgba(220,170,50,.9)) drop-shadow(0 0 12px rgba(196,120,0,.7)) brightness(1.12)}
.nav-logo-img{height:36px;width:auto;display:block;filter:brightness(0) invert(1)}
/* Hero text — margin-top:auto pushes it to bottom of flex column */
.auth-hero-text{position:relative;z-index:3;margin-top:auto}
.auth-hero-line{font-family:'Sora',sans-serif;font-size:38px;font-weight:700;color:#fff;line-height:1.08;letter-spacing:-.5px}
.auth-hero-line.italic{font-family:'Fraunces',serif;font-weight:300;font-style:italic;color:#c45c2a;font-size:40px}
.auth-hero-divider{width:38px;height:2px;background:linear-gradient(90deg,#c45c2a,#e8824a);margin:18px 0;border-radius:2px}
.auth-hero-desc{font-size:13px;color:rgba(255,255,255,.42);line-height:1.75;max-width:290px;font-weight:400;margin-bottom:28px}
/* Feature list */
.auth-feats-v2{display:flex;flex-direction:column;gap:15px}
.auth-feat-v2{display:flex;align-items:center;gap:14px}
.auth-feat-icon{width:38px;height:38px;border-radius:50%;border:1.5px solid rgba(196,92,42,.45);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px;background:rgba(196,92,42,.06)}
.auth-feat-title{font-size:13px;font-weight:700;color:rgba(255,255,255,.88);line-height:1.2}
.auth-feat-sub{font-size:11px;color:rgba(255,255,255,.35);margin-top:2px}
/* ─ Right panel ─ */
.auth-right{background:#0e0b08;display:flex;align-items:center;justify-content:center;padding:40px 36px;border-left:1px solid rgba(196,92,42,.12);position:relative}
.auth-card{width:100%;max-width:430px}
/* Card title/sub inside each section */
.auth-title{font-family:'Sora',sans-serif;font-size:26px;font-weight:700;color:#fff;margin-bottom:5px;letter-spacing:-.4px}
.auth-sub{font-size:13px;color:rgba(255,255,255,.38);margin-bottom:24px}
/* Tabs */
.atoggle{display:flex;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:4px;gap:3px;margin-bottom:26px;width:100%}
.atoggle-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 14px;border-radius:7px;border:none;background:none;font-size:13px;font-weight:600;color:rgba(255,255,255,.35);cursor:pointer;transition:all .18s;font-family:'Inter',sans-serif;white-space:nowrap}
.atoggle-btn svg{width:14px;height:14px;flex-shrink:0;stroke:currentColor}
.atoggle-btn.on{background:linear-gradient(135deg,#c45c2a,#e8824a);color:#fff;box-shadow:0 4px 16px rgba(196,92,42,.4)}
.atoggle-btn:not(.on):hover{color:rgba(255,255,255,.65);background:rgba(255,255,255,.06)}
/* Input icon wrapper */
.iw{position:relative;margin-bottom:14px}
.iw-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.28);pointer-events:none;display:flex;align-items:center}
.iw-icon svg{width:16px;height:16px;stroke:currentColor;fill:none}
.iw input{width:100%;padding:13px 44px;background:rgba(255,255,255,.055);border:1.5px solid rgba(255,255,255,.09);border-radius:10px;color:#fff;font-size:14px;font-weight:400;outline:none;transition:all .18s;font-family:'Inter',sans-serif}
.iw input::placeholder{color:rgba(255,255,255,.22)}
.iw input:focus{border-color:rgba(196,92,42,.55);background:rgba(196,92,42,.07);box-shadow:0 0 0 3px rgba(196,92,42,.11)}
.iw input:-webkit-autofill,.iw input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 30px #1a1008 inset!important;-webkit-text-fill-color:#fff!important}
.pass-eye{position:absolute;right:13px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:rgba(255,255,255,.28);display:flex;align-items:center;padding:2px;transition:color .15s}
.pass-eye:hover{color:rgba(255,255,255,.6)}
.pass-eye svg{width:16px;height:16px;stroke:currentColor;fill:none}
/* Forgot link */
.auth-forgot{display:block;text-align:right;font-size:12px;color:#e8824a;font-weight:600;cursor:pointer;margin-top:-4px;margin-bottom:18px;transition:color .15s}
.auth-forgot:hover{color:#c45c2a}
/* Auth primary btn */
.btn-auth-submit{width:100%;padding:14px;background:linear-gradient(135deg,#c45c2a 0%,#e8824a 100%);color:#fff;border:none;border-radius:10px;font-family:'Sora',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.01em;box-shadow:0 4px 20px rgba(196,92,42,.3)}
.btn-auth-submit:hover{background:linear-gradient(135deg,#a84d22 0%,#c45c2a 100%);transform:translateY(-2px);box-shadow:0 8px 28px rgba(196,92,42,.45)}
.btn-auth-submit:active{transform:scale(.98)}
/* Divider */
.auth-or{display:flex;align-items:center;gap:12px;margin:18px 0;color:rgba(255,255,255,.2);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.auth-or::before,.auth-or::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.08)}
/* Social buttons */
.auth-socials{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.auth-social-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:13px 18px;background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.12);border-radius:10px;cursor:pointer;transition:all .15s;font-family:'Inter',sans-serif;font-size:14px;font-weight:600;color:rgba(255,255,255,.85);letter-spacing:.01em}
.auth-social-btn:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.22);transform:translateY(-2px);box-shadow:0 4px 14px rgba(0,0,0,.25)}
.auth-social-btn svg{width:20px;height:20px;flex-shrink:0}
/* Legal footer */
.auth-legal-txt{text-align:center;font-size:11px;color:rgba(255,255,255,.22);line-height:1.7}
.auth-legal-txt .al{color:#e8824a;cursor:pointer;font-weight:600;transition:color .15s}
.auth-legal-txt .al:hover{color:#c45c2a}
/* Demo hint */
.hint-box{background:rgba(55,138,221,.1);border:1.5px solid rgba(55,138,221,.25);border-radius:8px;padding:10px 14px;font-size:12px;color:rgba(255,255,255,.5);text-align:center;margin-top:14px;line-height:1.5;font-family:'Inter',sans-serif}
.hint-box strong{color:#90b8f8;font-weight:700}
/* Compat shims (used by i18n/JS) */
.auth-brand,.auth-tagline,.auth-feats,.auth-feat,.auth-feat-dot{display:none!important}
/* Language toggle on auth (top-right) */
.auth-lang-corner{position:absolute;top:18px;right:20px;z-index:10}

/* ── NAV ── */
.topnav{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#111;border-bottom:2px solid #2a2a2a;position:sticky;top:0;z-index:50}
.nav-brand{display:flex;align-items:center}
.nav-brand span{color:#e8824a}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-pill{font-family:'Sora',sans-serif;display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.02em}
.np-green{background:#dcf5e7;color:#1a6e3a}
.np-gold{background:#fef3c7;color:#92660a}
.nav-av{width:34px;height:34px;border-radius:50%;background:#c45c2a;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;overflow:hidden}
.nav-av img{width:100%;height:100%;object-fit:cover}
.nav-name{font-size:13px;color:#e2ddd6;font-weight:600}

/* ── TABS ── */
.tabs{display:flex;background:#1a1a1a;border-bottom:3px solid #333}
.tab-btn{flex:1;padding:12px 4px;font-size:12px;font-weight:700;border:none;background:none;color:#bbb;font-family:inherit;cursor:pointer;border-bottom:3px solid transparent;transition:all .15s;margin-bottom:-3px;letter-spacing:.01em}
.tab-btn:hover{color:#fff;background:rgba(255,255,255,.07)}
.tab-btn.on{color:#fff;background:rgba(255,255,255,.1);border-bottom-color:#e8824a}
.tab-pane{display:none;padding:16px;background:#fff;overflow-y:auto;max-height:calc(100vh - 400px);min-height:220px}
.tab-pane.on{display:block}
.tab-pane::-webkit-scrollbar{width:5px}
.tab-pane::-webkit-scrollbar-track{background:#f5f2ed;border-radius:5px}
.tab-pane::-webkit-scrollbar-thumb{background:#c8c3bb;border-radius:5px}
.tab-pane::-webkit-scrollbar-thumb:hover{background:#a8a09a}

/* ── DASHBOARD ── */
.inf-dash{padding:20px 24px;background:#f5f2ed;min-height:calc(100vh - 58px)}
.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.dash-title{font-family:'Sora',sans-serif;font-size:22px;font-weight:700;color:#111;letter-spacing:-.3px}
.stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px;margin-bottom:18px}
.stat-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:14px 16px;box-shadow:0 2px 8px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);transition:box-shadow .2s,transform .2s;min-width:0;overflow:hidden}
.stat-card:hover{box-shadow:0 6px 20px rgba(0,0,0,.1);transform:translateY(-2px)}
.stat-val{font-family:'Sora',sans-serif;font-size:26px;font-weight:700;color:#111;letter-spacing:-.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.stat-val.stat-val-text{font-size:18px;letter-spacing:-.3px}
.stat-lbl{font-size:10px;color:#6b6760;margin-top:2px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.editor-layout{display:grid;grid-template-columns:1fr 220px;gap:16px;align-items:start}
.editor-card{background:#1a1a1a;border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.25)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sec-label{font-size:11px;font-weight:700;color:#111;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.divider{border:none;border-top:2px solid #e8e4db;margin:12px 0}

/* ── AVATAR UPLOAD ── */
.avatar-upload-wrap{display:flex;align-items:center;gap:14px;margin-bottom:14px;padding:14px;background:#f5f2ed;border:2px solid #c8c3bb;border-radius:10px;flex-wrap:wrap}
.avatar-preview{width:68px;height:68px;border-radius:50%;border:3px solid #c8c3bb;overflow:hidden;flex-shrink:0;background:#f0ece4;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative}
.avatar-preview:hover::after{content:'📷';position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;font-size:22px;border-radius:50%}
.avatar-upload-info{flex:1;font-size:12px;color:#6b6760;line-height:1.5}
.avatar-upload-info strong{color:#111;display:block;margin-bottom:3px;font-size:13px}

/* ── BANNER ADJUSTER ── */
.banner-adjuster{display:none;margin-top:8px;padding:12px;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.banner-adjuster.show{display:block}
.banner-adjuster label{font-size:11px;font-weight:700;color:#3a3835;text-transform:uppercase;letter-spacing:.04em;display:block;margin-bottom:6px}
.banner-adjuster input[type=range]{width:100%;accent-color:#c45c2a;cursor:pointer;margin-top:4px}
.banner-adj-preview{width:100%;height:60px;overflow:hidden;border-radius:6px;position:relative;background:#ddd;margin-bottom:8px;border:2px solid #c8c3bb}
.banner-adj-preview img{width:100%;position:absolute;left:0}

/* ── BANNER MODE ── */
.banner-toggle-row{display:flex;gap:8px;margin-bottom:14px}
.bmode-btn{flex:1;padding:9px 6px;border:2px solid #c8c3bb;border-radius:8px;background:#fff;color:#3a3835;font-size:12px;font-weight:700;cursor:pointer;text-align:center;transition:all .15s}
.bmode-btn.on{border-color:#111;background:#111;color:#fff}

/* ── PLATFORM GRID ── */
.platform-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:12px}
.plat-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border:2px solid #c8c3bb;border-radius:8px;background:#fff;cursor:pointer;transition:all .15s;font-size:10px;font-weight:700;color:#3a3835}
.plat-btn:hover{border-color:#c45c2a;background:#fdf0e8;color:#c45c2a;transform:scale(1.03)}
.plat-btn svg{width:22px;height:22px;flex-shrink:0}

/* ── LINK ITEMS ── */
.link-item{display:flex;align-items:center;gap:8px;padding:9px 10px;background:#f5f2ed;border:2px solid #c8c3bb;border-radius:8px;margin-bottom:8px;cursor:grab}
.link-item:active{cursor:grabbing}
.link-item.dragging{opacity:.4}
.link-item.drag-over{border-color:#c45c2a;background:#fdf0e8}
.link-icon-box{width:34px;height:34px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1.5px solid rgba(0,0,0,.1);overflow:hidden}
.link-icon-box svg{width:20px;height:20px}
.link-inputs{flex:1;display:flex;gap:6px;min-width:0}
.link-inputs input{flex:1;padding:7px 9px;border:2px solid #c8c3bb;border-radius:6px;font-size:12px;font-weight:500;color:#111;min-width:0;background:#fff;outline:none}
.link-inputs input:focus{border-color:#c45c2a}
.link-rm{background:#fff;border:2px solid #c0392b;border-radius:6px;cursor:pointer;color:#c0392b;font-size:13px;font-weight:700;padding:4px 7px;line-height:1;flex-shrink:0}
.link-rm:hover{background:#fdecea}
.link-drag{color:#999;font-size:16px;cursor:grab;padding:0 2px;flex-shrink:0;font-weight:700;user-select:none}
.link-clicks{font-size:10px;color:#6b6760;font-weight:700;background:#f0ece4;border:1.5px solid #c8c3bb;border-radius:4px;padding:2px 6px;flex-shrink:0;white-space:nowrap}

/* ── BG / GRAD ── */
.bg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px}
.bg-sw{height:44px;border-radius:8px;cursor:pointer;border:3px solid transparent;position:relative;overflow:hidden;transition:transform .1s}
.bg-sw:hover{transform:scale(1.06)}
.bg-sw.on{border-color:#fff;box-shadow:0 0 0 2px #111}
.bg-sw-lbl{position:absolute;bottom:2px;left:0;right:0;text-align:center;font-size:8px;color:rgba(255,255,255,.95);font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.6)}
.grad-row{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:10px}
.grad-dot{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:transform .1s}
.grad-dot:hover{transform:scale(1.12)}
.grad-dot.on{border-color:#111;box-shadow:0 0 0 1.5px #aaa}
.ls-opt{padding:9px 6px;border:2px solid #c8c3bb;border-radius:8px;background:#fff;text-align:center;cursor:pointer;font-size:11px;font-weight:700;color:#3a3835;transition:all .15s}
.ls-opt:hover{border-color:#c45c2a}
.ls-opt.on{border-color:#111;color:#111;background:#f5f2ed}

/* ── PHONE PREVIEW ── */
.phone-wrap{position:sticky;top:72px;align-self:start;isolation:isolate}
.phone-frame{width:200px;border-radius:28px;overflow:hidden;border:2px solid #1a1a1a;background:#fff;box-shadow:0 20px 60px rgba(0,0,0,.35),0 4px 16px rgba(0,0,0,.2),inset 0 0 0 1px rgba(255,255,255,.1);margin:0 auto}
.phone-bar{height:26px;background:#111;display:flex;align-items:center;justify-content:center}
.phone-pill{width:58px;height:6px;background:#333;border-radius:3px}
.lt-screen{min-height:380px;overflow:hidden}
.lt-av-photo{width:50px;height:50px;border-radius:50%;border:3px solid #fff;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;box-shadow:0 2px 10px rgba(0,0,0,.18);margin-bottom:5px;overflow:hidden;flex-shrink:0}
.lt-av-photo img{width:100%;height:100%;object-fit:cover}

/* ── PLAN CARDS ── */
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.plan-card{border:1px solid rgba(0,0,0,.08);border-radius:14px;padding:16px 12px;background:#fff;text-align:center;cursor:pointer;transition:all .2s;position:relative;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.plan-card:hover{border-color:#c45c2a;box-shadow:0 8px 24px rgba(196,92,42,.15);transform:translateY(-2px)}
.plan-card.on{border-color:#111;background:#111;box-shadow:0 12px 32px rgba(0,0,0,.25);transform:translateY(-3px)}
.plan-card.on .plan-name,.plan-card.on .plan-price,.plan-card.on .plan-feat,.plan-card.on .plan-sub{color:#fff!important;font-family:'Sora',sans-serif}
.plan-popular{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:#c45c2a;color:#fff;font-size:9px;font-weight:700;padding:3px 12px;border-radius:20px;white-space:nowrap;letter-spacing:.04em}
.plan-name{font-size:11px;font-weight:700;color:#111;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.plan-price{font-family:'Sora',sans-serif;font-size:24px;font-weight:700;color:#111;letter-spacing:-.5px}
.plan-sub{font-size:10px;color:#6b6760;margin-bottom:10px}
.plan-feat{font-size:11px;color:#3a3835;line-height:1.7;font-weight:500;text-align:left;white-space:pre-line}

/* ── PUBLIC PROFILE ── */
.pub-profile{min-height:calc(100vh - 58px);display:flex;align-items:flex-start;justify-content:center;padding:30px 16px;background:#f5f2ed;font-family:'Inter',sans-serif}
.pub-inner{width:100%;max-width:400px}
.pub-banner{height:130px;border-radius:16px 16px 0 0;overflow:hidden;position:relative}
.pub-body{padding:0 22px 30px;background:#fff;border-radius:0 0 16px 16px}
.pub-av{width:76px;height:76px;border-radius:50%;border:4px solid #fff;margin-top:-38px;margin-bottom:10px;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;box-shadow:0 4px 16px rgba(0,0,0,.15);position:relative;z-index:2}
.pub-av img{width:100%;height:100%;object-fit:cover}
.pub-name{font-family:'Sora',sans-serif;font-size:22px;font-weight:700;color:#111;margin-bottom:2px;letter-spacing:-.3px}
.pub-handle{font-family:'Inter',sans-serif;font-size:13px;color:#6b6760;margin-bottom:8px;font-weight:500}
.pub-bio{font-family:'Inter',sans-serif;font-size:14px;color:#3a3835;line-height:1.6;margin-bottom:18px;white-space:pre-wrap;word-break:break-word}
.pub-link{font-family:'Sora',sans-serif;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 16px;border-radius:10px;margin-bottom:8px;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .15s;cursor:pointer;letter-spacing:.01em}
.pub-link:hover{opacity:.85}
.pub-link svg{width:18px;height:18px;flex-shrink:0}
/* ── IMAGE LINK CARDS */
.pub-link-card{position:relative;width:100%;height:190px;border-radius:16px;overflow:hidden;margin-bottom:10px;cursor:pointer;display:block;border:none;padding:0}
.pub-link-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.pub-link-card:hover img{transform:scale(1.04)}
.pub-link-card-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(0,0,0,.78) 100%);pointer-events:none}
.pub-link-card-label{position:absolute;bottom:14px;left:14px;color:#fff;font-weight:700;font-size:15px;font-family:'Sora',sans-serif;text-shadow:0 1px 6px rgba(0,0,0,.5);max-width:calc(100% - 56px);line-height:1.2;pointer-events:none}
/* ── LINK IMAGE UPLOAD (Pro/Premium) */
.link-img-cell{display:flex;align-items:center;justify-content:center;flex-shrink:0}
.link-img-thumb{position:relative;width:32px;height:32px;border-radius:6px;overflow:visible;flex-shrink:0}
.link-img-thumb img{width:32px;height:32px;border-radius:6px;object-fit:cover;border:2px solid #c8c3bb;display:block}
.link-img-rm{position:absolute;top:-5px;right:-5px;width:16px;height:16px;background:#c0392b;color:#fff;border:none;border-radius:50%;font-size:9px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;z-index:2;transition:transform .12s}
.link-img-rm:hover{transform:scale(1.2)}
.link-img-add{width:32px;height:32px;border:2px dashed #c8c3bb;border-radius:6px;background:transparent;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;padding:0}
.link-img-add:hover{border-color:#c45c2a;background:#fdf8f4}
.link-img-lock{width:32px;height:32px;border-radius:6px;border:2px solid #e8e4db;display:flex;align-items:center;justify-content:center;font-size:12px;opacity:.4;flex-shrink:0;cursor:default}
.link-img-quota{font-size:11px;color:#6b6760;font-weight:600;padding:7px 10px;background:#f5f2ed;border-radius:8px;margin-bottom:4px;display:flex;align-items:center;gap:6px;border:1.5px solid #e0dbd2}
.link-img-quota.full{color:#c45c2a;background:#fdf0e8;border-color:#f0c8a8}
.link-img-quota strong{color:#111}
.link-img-res-note{font-size:10.5px;color:#a09a92;margin-bottom:10px;padding:0 2px;display:flex;align-items:center;gap:4px}
/* ── LINK IMAGE POSITION ADJUSTER */
.link-item{flex-wrap:wrap}
.link-img-pos-row{width:100%;display:flex;align-items:center;gap:8px;padding:7px 4px 2px;border-top:1.5px solid #e8e4db;margin-top:4px;flex-shrink:0}
.link-img-pos-prev{width:52px;height:32px;border-radius:5px;object-fit:cover;flex-shrink:0;border:1.5px solid #c8c3bb;transition:none}
.link-img-pos-label{font-size:10px;color:#6b6760;font-weight:700;flex-shrink:0;display:flex;align-items:center;gap:3px}
.link-img-pos-slider{flex:1;height:3px;accent-color:#c45c2a;cursor:pointer;min-width:0}
.link-img-pos-val{font-size:10px;color:#6b6760;font-weight:700;min-width:28px;text-align:right;flex-shrink:0}
.pub-footer{text-align:center;margin-top:22px;font-size:12px;color:#aaa}
.pub-footer span{color:#c45c2a;font-weight:700}

/* ── ANALYTICS ── */
.analytics-item{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid #f0ece4;gap:10px}
.analytics-item:last-child{border-bottom:none}
.analytics-bar-wrap{flex:1;height:8px;background:#f0ece4;border-radius:4px;overflow:hidden}
.analytics-bar{height:100%;background:#c45c2a;border-radius:4px;transition:width .3s}
/* ── ANALYTICS REDESIGN ── */
.an-period-row{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap;align-items:center}
.an-period-btn{padding:5px 13px;border-radius:20px;border:2px solid #e0dbd2;background:#f8f5f0;font-size:12px;font-weight:700;color:#6b6760;cursor:pointer;font-family:inherit;transition:all .15s}
.an-period-btn.on,.an-period-btn:hover{background:#c45c2a;border-color:#c45c2a;color:#fff}
.an-custom-row{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.an-custom-row label{font-size:11px;color:#6b6760;font-weight:700;white-space:nowrap}
.an-custom-row input[type=date]{flex:1;min-width:110px;padding:6px 8px;border:2px solid #e0dbd2;border-radius:8px;font-size:12px;color:#111;background:#fff;font-family:inherit;cursor:pointer}
.an-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.an-sum-card{background:#f8f5f0;border:2px solid #e0dbd2;border-radius:12px;padding:12px 6px;text-align:center}
.an-sum-val{font-size:20px;font-weight:800;color:#111;font-family:'Sora',sans-serif;line-height:1.1}
.an-sum-lbl{font-size:10px;color:#6b6760;font-weight:600;margin-top:3px;text-transform:uppercase;letter-spacing:.04em}
.an-chart-wrap{background:#f8f5f0;border:2px solid #e0dbd2;border-radius:12px;padding:14px 12px 10px;margin-bottom:16px}
.an-chart-title{font-size:11px;font-weight:700;color:#6b6760;text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.an-chart-svg{width:100%;display:block;overflow:visible}
.an-no-data{text-align:center;padding:24px;color:#a09a92;font-size:12px;font-weight:500}

/* ── AVATAR FRAME OPTS ── */
.av-frame-opts{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.av-frame-opt{padding:5px 13px;border-radius:20px;border:2px solid #e0dbd2;background:#f8f5f0;font-size:11px;font-weight:700;color:#6b6760;cursor:pointer;font-family:inherit;transition:all .15s}
.av-frame-opt.on,.av-frame-opt:hover{background:#111;border-color:#111;color:#fff}

/* ── TEXT SIZE / STYLE BTNS ── */
.txt-sz-btn{padding:5px 12px;border-radius:20px;border:2px solid #e0dbd2;background:#f8f5f0;font-size:11px;font-weight:700;color:#6b6760;cursor:pointer;font-family:inherit;transition:all .15s;line-height:1}
.txt-sz-btn.on,.txt-sz-btn:hover{background:#c45c2a;border-color:#c45c2a;color:#fff}

/* ── URL BOX ── */
.url-box{background:linear-gradient(135deg,#fff,#f5f2ed);border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.url-box-link{font-size:13px;font-weight:700;color:#c45c2a;word-break:break-all}
.char-counter{font-size:11px;color:#6b6760;text-align:right;margin-top:4px;font-weight:600}
.char-counter.warn{color:#c45c2a}

/* ── ADMIN ── */
.admin-shell{display:flex;height:calc(100vh - 58px)}
.admin-sidebar{width:200px;background:linear-gradient(180deg,#111 0%,#161616 100%);flex-shrink:0;display:flex;flex-direction:column;box-shadow:4px 0 16px rgba(0,0,0,.15)}
.admin-sidebar-brand{padding:18px 16px;font-family:'Sora',sans-serif;font-size:15px;font-weight:700;color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}
.admin-sidebar-brand span{color:#e8824a}
.a-nav{padding:10px 0;flex:1}
.a-nav-item{display:flex;align-items:center;gap:10px;padding:12px 16px;font-size:13px;font-weight:600;color:rgba(255,255,255,.5);cursor:pointer;transition:all .1s;border-left:3px solid transparent}
.a-nav-item:hover{background:rgba(255,255,255,.07);color:#ddd}
.a-nav-item.on{background:rgba(255,255,255,.1);color:#fff;border-left-color:#e8824a}
.admin-content{flex:1;overflow-y:auto;background:#f5f2ed}
.a-sec{display:none;padding:22px}.a-sec.on{display:block}
.a-page-title{font-family:'Sora',sans-serif;font-size:20px;font-weight:700;margin-bottom:14px;color:#111;letter-spacing:-.3px}
.search-bar{position:relative;margin-bottom:12px}
.search-bar input{width:100%;padding:9px 12px 9px 38px;border:2px solid #c8c3bb;border-radius:8px;background:#fff;color:#111;font-size:13px;font-weight:500;outline:none}
.search-bar input:focus{border-color:#c45c2a}
.s-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none}
.table-wrap{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:14px;overflow:hidden;overflow-x:auto;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.tbl{width:100%;border-collapse:collapse;min-width:600px}
.tbl th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;color:#6b6760;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e2ddd6;background:#f0ece4;white-space:nowrap}
.tbl td{padding:10px 14px;font-size:13px;color:#3a3835;border-bottom:1px solid #f0ece4;font-weight:500}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:#faf8f4}
.tbl-pill{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}
.tp-green{background:#dcf5e7;color:#1a6e3a}
.tp-red{background:#fdecea;color:#c0392b}
.tbl-acts{display:flex;gap:6px}
.s-card{background:#fff;border:2px solid #c8c3bb;border-radius:12px;padding:18px;margin-bottom:14px}
.s-card-title{font-size:12px;font-weight:700;color:#111;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid #e2ddd6;text-transform:uppercase;letter-spacing:.05em}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #f0ece4}
.toggle-row:last-child{border-bottom:none}
.tgl-label{font-size:13px;font-weight:600;color:#111}
.tgl-desc{font-size:11px;color:#6b6760;margin-top:2px}
.tgl{position:relative;width:40px;height:22px;flex-shrink:0}
.tgl input{opacity:0;width:0;height:0;position:absolute}
.tgl-sl{position:absolute;inset:0;background:#c8c3bb;border-radius:22px;cursor:pointer;transition:.2s}
.tgl-sl:before{content:'';position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.tgl input:checked+.tgl-sl{background:#c45c2a}
.tgl input:checked+.tgl-sl:before{transform:translateX(18px)}

/* ── MODAL ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:300;align-items:center;justify-content:center}
.modal-bg.open{display:flex}
.modal-box{background:rgba(255,255,255,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px;padding:26px;width:340px;box-shadow:0 24px 64px rgba(0,0,0,.2),0 4px 16px rgba(0,0,0,.08);border:1px solid rgba(0,0,0,.06)}
.modal-title{font-size:16px;font-weight:700;margin-bottom:16px;color:#111}
.modal-footer{display:flex;gap:8px;margin-top:18px}
.modal-footer .btn{flex:1;padding:11px}

/* ── TOAST ── */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:rgba(15,15,15,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:#fff;padding:12px 28px;border-radius:30px;font-family:'Sora',sans-serif;font-size:13px;font-weight:600;z-index:999;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;border:1px solid rgba(255,255,255,.12);box-shadow:0 8px 32px rgba(0,0,0,.3);white-space:nowrap}

/* ── COLOR SECTION CARDS ── */
.color-section-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:14px;margin-bottom:12px;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.color-section-title{font-size:12px;font-weight:700;color:#111;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;padding-bottom:8px;border-bottom:1.5px solid #e2ddd6}
.color-picker-row{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap}
.color-picker-group{flex-shrink:0}
.color-picker-label{font-size:10px;color:#6b6760;margin-bottom:5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
/* Button palette swatches */
.btn-palette{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:20px;cursor:pointer;border:2px solid transparent;transition:all .15s;font-size:11px;font-weight:600}
.btn-palette:hover{border-color:#111;transform:scale(1.05)}
.btn-palette.active{border-color:#111}
.btn-palette-preview{width:18px;height:18px;border-radius:50%;border:1.5px solid rgba(0,0,0,.15);flex-shrink:0}
/* Text theme swatches */
.text-theme-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;background:#fff;border:2px solid #c8c3bb;border-radius:20px;cursor:pointer;font-size:11px;font-weight:600;color:#111;transition:all .15s}
.text-theme-btn:hover{border-color:#c45c2a}
/* ── THEME SYSTEM V2 ── */
.theme-grid-v2{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.theme-card-v2{border-radius:12px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .22s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 12px rgba(0,0,0,.25);position:relative}
.theme-card-v2:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.4);border-color:rgba(232,130,74,.35)}
.theme-card-v2.active{border-color:#e8824a;box-shadow:0 0 0 2px rgba(232,130,74,.5),0 8px 24px rgba(0,0,0,.35)}
.theme-card-v2.locked{cursor:default}
.theme-card-v2.locked:hover{transform:none;border-color:transparent;box-shadow:0 2px 12px rgba(0,0,0,.25)}
.theme-mini-preview{height:112px;overflow:hidden;position:relative}
.theme-card-footer-bar{padding:8px 10px;background:#0d0d0d;border-top:1px solid rgba(255,255,255,.06)}
.theme-cat-strip{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}
.theme-cat-btn{padding:4px 10px;border-radius:20px;font-size:10px;font-weight:700;cursor:pointer;border:1.5px solid rgba(255,255,255,.15);background:transparent;color:rgba(255,255,255,.5);transition:all .15s;font-family:'Sora',sans-serif;white-space:nowrap}
.theme-cat-btn:hover{border-color:rgba(232,130,74,.5);color:#e8824a}
.theme-cat-btn.on{background:#e8824a;color:#fff;border-color:#e8824a}
/* Neon glow for Neon Nights theme — applied via JS */
.neon-glow{box-shadow:0 0 10px currentColor,0 0 20px currentColor,0 0 40px currentColor!important;text-shadow:0 0 8px currentColor}
/* ── GLOBAL TRANSITIONS & DEPTH ── */
/* Selective transitions — only on interactive elements */
.btn,.plan-card,.stat-card,.s-card,.color-section-card,.link-item,.plat-btn,.ls-opt,.bmode-btn,.atoggle-btn,.bg-sw,.grad-dot,.a-nav-item,.tab-btn,.tbl-pill,.tbl tr{transition:all .18s cubic-bezier(.4,0,.2,1)}
/* Glass utility */
.glass{background:rgba(255,255,255,.08)!important;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12)!important}
/* Link item hover lift */
.link-item:hover{box-shadow:0 2px 10px rgba(0,0,0,.08);transform:translateX(2px)}
/* Platform button hover */
.plat-btn:hover{box-shadow:0 4px 12px rgba(0,0,0,.1)}
/* Banners depth */
#trial-banner,#user-promo-banner,#grace-warning-banner,#demo-hint-bar{box-shadow:0 4px 20px rgba(0,0,0,.12)}
/* Phone subtle ambient glow */
.phone-wrap{position:sticky;top:72px;align-self:start;isolation:isolate}
.phone-wrap::before{content:'';position:absolute;inset:-30px;border-radius:50%;background:radial-gradient(ellipse at center,rgba(196,92,42,.1) 0%,transparent 70%);pointer-events:none;z-index:-1}
/* ── ANIMATION SYSTEM ── */

/* Page transitions */
.page.active{animation:pageIn .28s cubic-bezier(.4,0,.2,1)}
@keyframes pageIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Fade in up — for cards, lists, banners loading in */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(12px)}to{opacity:1;transform:translateX(0)}}
@keyframes popIn{from{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes spinIn{from{opacity:0;transform:rotate(-8deg) scale(.95)}to{opacity:1;transform:rotate(0) scale(1)}}
@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* Staggered children animation */
.anim-stagger>*{opacity:0;animation:fadeUp .3s cubic-bezier(.4,0,.2,1) forwards}
.anim-stagger>*:nth-child(1){animation-delay:.05s}
.anim-stagger>*:nth-child(2){animation-delay:.1s}
.anim-stagger>*:nth-child(3){animation-delay:.15s}
.anim-stagger>*:nth-child(4){animation-delay:.2s}
.anim-stagger>*:nth-child(5){animation-delay:.25s}
.anim-stagger>*:nth-child(6){animation-delay:.3s}
.anim-stagger>*:nth-child(7){animation-delay:.35s}
.anim-stagger>*:nth-child(8){animation-delay:.4s}

/* Utility animation classes */
.anim-fadeup{animation:fadeUp .3s cubic-bezier(.4,0,.2,1) forwards}
.anim-fadein{animation:fadeIn .25s ease forwards}
.anim-scalein{animation:scaleIn .25s cubic-bezier(.34,1.56,.64,1) forwards}
.anim-popin{animation:popIn .3s cubic-bezier(.34,1.56,.64,1) forwards}
.anim-slidein-left{animation:slideInLeft .25s cubic-bezier(.4,0,.2,1) forwards}
.anim-slidein-right{animation:slideInRight .25s cubic-bezier(.4,0,.2,1) forwards}

/* Skeleton loading shimmer */
.skeleton{background:linear-gradient(90deg,#f0ece4 25%,#e8e4db 50%,#f0ece4 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}
.skeleton-dark{background:linear-gradient(90deg,#2a2a2a 25%,#333 50%,#2a2a2a 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}

/* Live indicator dot */
.live-dot{width:7px;height:7px;border-radius:50%;background:#1DB954;animation:pulse 2s infinite;display:inline-block}

/* Animated gradient background for premium elements */
.anim-gradient{background-size:300% 300%;animation:gradientShift 4s ease infinite}

/* Toast entrance */
#toast{transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.34,1.56,.64,1)!important}
#toast[style*="opacity:1"]{transform:translateX(-50%) translateY(0)!important}
#toast[style*="opacity:0"]{transform:translateX(-50%) translateY(8px)!important}

/* Modal entrance */
.modal-bg.open .modal-box{animation:scaleIn .22s cubic-bezier(.34,1.56,.64,1)}
#onboarding-modal.open .modal-box,.modal-bg.open>div{animation:popIn .28s cubic-bezier(.34,1.56,.64,1)}
.modal-bg{transition:background .2s}

/* Button press effect */
.btn:active{transform:scale(.97)!important}

/* Phone preview — subtle float */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.phone-frame{animation:float 4s ease-in-out infinite}

/* Tab switch */
.tab-pane.on{animation:fadeIn .18s ease}

/* Link items entrance when rendered */
.link-item{animation:slideInLeft .2s cubic-bezier(.4,0,.2,1) both}

/* Platform buttons pop in */
.plat-btn{animation:scaleIn .2s cubic-bezier(.34,1.56,.64,1) both}

/* Stats cards entrance */
.stats-row{animation:fadeUp .3s cubic-bezier(.4,0,.2,1)}

/* Editorial theme cards — V2: block container, inner grid handled by .theme-grid-v2 */
#editorial-themes-grid{display:block}
#editorial-themes-grid .theme-card-v2{animation:scaleIn .25s cubic-bezier(.34,1.56,.64,1) both}
#editorial-themes-grid .theme-card-v2:nth-child(2){animation-delay:.05s}
#editorial-themes-grid .theme-card-v2:nth-child(3){animation-delay:.1s}
#editorial-themes-grid .theme-card-v2:nth-child(4){animation-delay:.15s}
#editorial-themes-grid .theme-card-v2:nth-child(5){animation-delay:.2s}
#editorial-themes-grid .theme-card-v2:nth-child(6){animation-delay:.25s}
#editorial-themes-grid .theme-card-v2:nth-child(7){animation-delay:.3s}
#editorial-themes-grid .theme-card-v2:nth-child(8){animation-delay:.35s}

/* Nav avatar bounce on login */
@keyframes avatarIn{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}
.nav-av{animation:avatarIn .4s cubic-bezier(.34,1.56,.64,1)}

/* Plan card selected bounce */
.plan-card.on{animation:popIn .25s cubic-bezier(.34,1.56,.64,1)!important}

/* Grace/trial banners slide in */
#grace-warning-banner,#trial-banner,#user-promo-banner,#demo-hint-bar{animation:slideInLeft .3s cubic-bezier(.4,0,.2,1)}

/* Preview refresh flash */
@keyframes previewFlash{0%{opacity:1}30%{opacity:.7}100%{opacity:1}}
.preview-refresh{animation:previewFlash .25s ease}
/* Tab active glow underline */
.tab-btn.on{text-shadow:0 0 12px rgba(232,130,74,.4)}
/* Input depth */
.fg input,.fg select,.fg textarea{box-shadow:0 1px 3px rgba(0,0,0,.05)}
/* Stat card hover */
.stat-card:hover{box-shadow:0 6px 20px rgba(0,0,0,.1);transform:translateY(-2px)}
/* A nav active glow */
.a-nav-item.on::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#e8824a,#c45c2a);border-radius:0 3px 3px 0}
.a-nav-item{position:relative}

/* ══════════════════════════════════════════════
   MOTION LAYER v2 — Fade · Hover · Glow · Micro
   ══════════════════════════════════════════════ */

/* New keyframes */
@keyframes ripple{0%{transform:scale(0);opacity:.6}100%{transform:scale(6);opacity:0}}
@keyframes glowPulse{0%,100%{box-shadow:0 12px 32px rgba(0,0,0,.25),0 0 0 0 rgba(196,92,42,.4)}55%{box-shadow:0 12px 32px rgba(0,0,0,.25),0 0 0 10px rgba(196,92,42,0)}}
@keyframes tabSpring{0%{transform:scale(1)}30%{transform:scale(.95)}70%{transform:scale(1.03)}100%{transform:scale(1)}}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-5px)}40%,80%{transform:translateX(5px)}}
@keyframes cardReveal{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes saveFlash{0%,100%{background:#111;border-color:#111}45%{background:#16a34a;border-color:#16a34a;color:#fff}}
.anim-shake{animation:shake .35s cubic-bezier(.36,.07,.19,.97)}
.card-reveal{animation:cardReveal .32s cubic-bezier(.4,0,.2,1) forwards}

/* ── Ripple on buttons ── */
.btn{position:relative!important;overflow:hidden!important}
.ripple-wave{position:absolute;border-radius:50%;width:6px;height:6px;margin-left:-3px;margin-top:-3px;background:rgba(255,255,255,.42);transform:scale(0);animation:ripple .55s linear;pointer-events:none;z-index:9}

/* ── Button hover depth ── */
.btn-primary:hover{transform:translateY(-2px)!important;box-shadow:0 6px 22px rgba(196,92,42,.44)!important}
.btn-dark:hover{transform:translateY(-2px)!important;box-shadow:0 6px 22px rgba(0,0,0,.3)!important}
.btn-outline:hover{transform:translateY(-2px)!important;box-shadow:0 4px 14px rgba(0,0,0,.07)!important}
.btn:active{transform:scale(.96)!important;transition:transform .08s!important}

/* ── Color-section-card hover glow ── */
.color-section-card{transition:transform .22s cubic-bezier(.4,0,.2,1),box-shadow .22s,border-color .22s}
.color-section-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.08),0 0 0 1.5px rgba(196,92,42,.2)}

/* ── Link item hover ── */
.link-item{transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s!important}
.link-item:hover{transform:translateY(-2px)!important;box-shadow:0 6px 22px rgba(0,0,0,.1)!important}

/* ── Stat card deep glow ── */
.stat-card{transition:box-shadow .22s,transform .22s!important}
.stat-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.1),0 0 0 1.5px rgba(196,92,42,.14),0 0 24px rgba(196,92,42,.07)!important;transform:translateY(-3px)!important}

/* ── Analytics sum card hover ── */
.an-sum-card{transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .22s,border-color .22s}
.an-sum-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(196,92,42,.14);border-color:rgba(196,92,42,.5)}

/* ── Analytics chart wrap hover ── */
.an-chart-wrap{transition:box-shadow .22s,border-color .22s}
.an-chart-wrap:hover{border-color:rgba(196,92,42,.3);box-shadow:0 6px 20px rgba(0,0,0,.06)}

/* ── Plan card selected glow pulse ── */
.plan-card.on{animation:popIn .25s cubic-bezier(.34,1.56,.64,1),glowPulse 2.8s .3s ease-in-out infinite!important}

/* ── Avatar upload hover ── */
.avatar-upload-wrap{transition:border-color .2s,box-shadow .2s,background .2s}
.avatar-upload-wrap:hover{border-color:#c45c2a;box-shadow:0 4px 18px rgba(196,92,42,.12);background:#fdf5f1}
.avatar-preview{transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s}
.avatar-preview:hover{transform:scale(1.07);box-shadow:0 8px 24px rgba(0,0,0,.16)}

/* ── Platform btn hover glow ── */
.plat-btn{transition:transform .18s cubic-bezier(.34,1.56,.64,1),border-color .15s,background .15s,box-shadow .18s}
.plat-btn:hover{box-shadow:0 4px 14px rgba(196,92,42,.2)!important}

/* ── Bg swatch hover glow ── */
.bg-sw{transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s}
.bg-sw:hover{box-shadow:0 4px 14px rgba(0,0,0,.14)!important}

/* ── Frame opts micro-spring ── */
.av-frame-opt{transition:transform .18s cubic-bezier(.34,1.56,.64,1),background .15s,border-color .15s,box-shadow .15s}
.av-frame-opt:hover{transform:scale(1.05)}
.av-frame-opt.on{box-shadow:0 2px 12px rgba(17,17,17,.18)}

/* ── Txt size buttons ── */
.txt-sz-btn{transition:transform .15s cubic-bezier(.34,1.56,.64,1),background .15s,border-color .15s}
.txt-sz-btn:hover{transform:scale(1.06)}
.txt-sz-btn:active{transform:scale(.94)!important}

/* ── Input focus shine ── */
.fg input:focus,.fg select:focus,.fg textarea:focus{box-shadow:0 0 0 3px rgba(196,92,42,.15),0 2px 10px rgba(196,92,42,.09)!important;transition:all .2s!important}

/* ── Tab btn spring on select ── */
.tab-btn{transition:all .15s}
.tab-btn.on{animation:tabSpring .32s cubic-bezier(.34,1.56,.64,1)!important}

/* ── Page in: slightly deeper ── */
.page.active{animation:pageIn .3s cubic-bezier(.4,0,.2,1)}

/* ── Save button flash ── */
.btn-save-flash{animation:saveFlash .65s ease!important}

/* ── Toast depth ── */
#toast{box-shadow:0 6px 24px rgba(0,0,0,.22),0 0 0 1px rgba(255,255,255,.08)!important}

/* ── Analytics period btn hover ── */
.an-period-btn{transition:all .18s cubic-bezier(.34,1.56,.64,1)}
.an-period-btn:hover{transform:scale(1.04)}

/* ── Modal entrance — deeper spring ── */
.modal-bg.open .modal-box{animation:popIn .3s cubic-bezier(.34,1.56,.64,1)}

/* BILLING CYCLE TOGGLE */
.cycle-toggle{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:20px}
.cycle-toggle-track{position:relative;width:52px;height:28px;background:#c8c3bb;border-radius:28px;cursor:pointer;transition:background .2s;flex-shrink:0;border:2px solid #c8c3bb}
.cycle-toggle-track.annual{background:#c45c2a;border-color:#c45c2a}
.cycle-toggle-knob{position:absolute;width:22px;height:22px;background:#fff;border-radius:50%;top:1px;left:1px;transition:left .2s;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.cycle-toggle-track.annual .cycle-toggle-knob{left:25px}
.cycle-label{font-size:13px;font-weight:600;color:#6b6760;cursor:pointer;transition:color .2s}
.cycle-label.active{color:#111}
.cycle-badge{display:inline-flex;align-items:center;background:#dcf5e7;color:#1a6e3a;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;margin-left:5px;letter-spacing:.02em}
/* Plan card annual extras */
.plan-original-price{font-size:11px;color:#aaa;text-decoration:line-through;margin-bottom:1px}
.plan-save-badge{display:inline-block;background:#dcf5e7;color:#1a6e3a;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;margin-top:4px;letter-spacing:.02em}
.plan-billed-note{font-size:10px;color:#6b6760;margin-top:3px}
.lang-selector{position:relative;display:inline-block}
.lang-btn{display:flex;align-items:center;gap:6px;background:#fff;border:2px solid #3a3835;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:700;color:#111;cursor:pointer;transition:all .15s;font-family:'Inter',sans-serif}
.lang-btn:hover{background:#f0ece4}
.lang-btn-dark{background:rgba(255,255,255,.1)!important;border-color:rgba(255,255,255,.3)!important;color:#fff!important}
.lang-btn-dark:hover{background:rgba(255,255,255,.2)!important}
.lang-dropdown{display:none;position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:2px solid #c8c3bb;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.18);z-index:200;min-width:180px;overflow:hidden}
.lang-dropdown.open{display:block}
.lang-option{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:13px;font-weight:500;color:#111;cursor:pointer;transition:background .1s;border-bottom:1px solid #f0ece4}
.lang-option:last-child{border-bottom:none}
.lang-option:hover{background:#f5f2ed}
.lang-option.active{background:#fdf0e8;color:#c45c2a;font-weight:700}
.lang-flag{font-size:18px;line-height:1}
.lang-auth-bar{display:flex;justify-content:flex-end;padding:10px 14px 0;gap:8px;align-items:center}
.lang-auth-label{font-size:12px;color:#6b6760;font-weight:500}

/* ── PLATFORM SEARCH & GRID ── */
.plat-search-wrap{position:relative;margin-bottom:8px}
.plat-search-wrap input{width:100%;padding:8px 10px 8px 32px;border:2px solid #c8c3bb;border-radius:8px;font-size:12px;font-weight:500;background:#faf8f4;color:#111;outline:none;transition:border-color .15s}
.plat-search-wrap input:focus{border-color:#c45c2a;background:#fff}
.plat-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:13px;pointer-events:none}
.platform-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;max-height:170px;overflow-y:auto;padding-right:2px;margin-bottom:4px}
.platform-grid::-webkit-scrollbar{width:4px}
.platform-grid::-webkit-scrollbar-track{background:#f0ece4;border-radius:4px}
.platform-grid::-webkit-scrollbar-thumb{background:#c8c3bb;border-radius:4px}
/* ── CUSTOM URL ADD ── */
.custom-url-box{background:#f5f2ed;border:2px dashed #c8c3bb;border-radius:10px;padding:12px;margin-top:8px;margin-bottom:12px;transition:border-color .15s}
.custom-url-box:focus-within{border-color:#c45c2a;border-style:solid;background:#fdf8f4}
.custom-url-label{font-size:10px;font-weight:700;color:#3a3835;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.custom-url-row{display:grid;grid-template-columns:1fr 1.7fr auto;gap:6px;align-items:center}
.custom-url-row input{padding:8px 10px;border:2px solid #c8c3bb;border-radius:7px;font-size:12px;font-weight:500;background:#fff;color:#111;outline:none;transition:border-color .15s;min-width:0}
.custom-url-row input:focus{border-color:#c45c2a}
.custom-url-row input::placeholder{color:#aaa}
.custom-url-add-btn{padding:8px 14px;background:#111;color:#fff;border:none;border-radius:7px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;font-family:'Sora',sans-serif;transition:all .15s;flex-shrink:0}
.custom-url-add-btn:hover{background:#333;transform:translateY(-1px)}
.custom-url-add-btn:active{transform:scale(.97)}
/* ── LEGAL EDITOR (admin) ── */
.legal-tab-strip{display:flex;background:#e2ddd6;border-radius:10px;padding:3px;gap:2px;margin-bottom:18px}
.legal-tab-btn{flex:1;padding:8px 6px;border-radius:7px;border:2px solid transparent;background:none;font-family:'Sora',sans-serif;font-size:11px;font-weight:700;color:#3a3835;cursor:pointer;transition:all .15s;white-space:nowrap}
.legal-tab-btn.on{background:#fff;color:#111;border-color:#c8c3bb;box-shadow:0 1px 4px rgba(0,0,0,.12)}
.legal-section-card{background:#fff;border:2px solid #c8c3bb;border-radius:10px;padding:14px 16px;margin-bottom:10px;position:relative}
.legal-section-card:hover{border-color:#c45c2a}
.legal-section-num{position:absolute;top:-10px;left:14px;background:#111;color:#fff;font-family:'Sora',sans-serif;font-size:10px;font-weight:700;padding:2px 10px;border-radius:20px}

/* ══════════════════════════════════════════════
   RESPONSIVE — Tablet (≤ 1023px) & Mobile (≤ 767px)
   ══════════════════════════════════════════════ */

/* ─── TABLET ─────────────────────────────────── */
@media (max-width:1023px){
  .editor-layout{grid-template-columns:1fr}
  .phone-wrap{position:static;display:flex;justify-content:center;margin-top:20px}
  .phone-wrap::before{display:none}
  .plans-grid{grid-template-columns:repeat(2,1fr)}
}

/* ─── MOBILE ─────────────────────────────────── */
@media (max-width:767px){

  /* ── AUTH ── */
  .auth-shell{grid-template-columns:1fr}
  /* Collapse left panel to a slim logo bar */
  .auth-left{
    padding:14px 20px;
    flex-direction:row;
    justify-content:center;
    align-items:center;
    min-height:0;
    height:auto;
    overflow:visible;
  }
  .auth-left::before,.auth-left::after{display:none}
  .auth-fig-wrap{display:none}
  .auth-brand-block{
    position:static;
    transform:none;
    width:72px;
    margin:0 auto;
  }
  .auth-hero-text{display:none}
  .auth-right{
    border-left:none;
    border-top:1px solid rgba(196,92,42,.15);
    padding:22px 20px 36px;
    min-height:0;
    align-items:flex-start;
  }
  .auth-card{max-width:100%;width:100%}
  .auth-lang-corner{top:10px;right:12px}
  .auth-title{font-size:22px}
  .atoggle-btn{font-size:12px;padding:9px 10px}

  /* ── NAV ── */
  .topnav{padding:8px 12px;gap:6px;flex-wrap:nowrap}
  .nav-name{display:none}
  .nav-right{gap:6px}
  .nav-right .btn-danger{font-size:11px;padding:6px 10px}
  .nav-logo-img{height:26px}
  .nav-pill{font-size:10px;padding:2px 8px}

  /* ── DASHBOARD ── */
  .inf-dash{padding:12px 12px}
  .dash-header{flex-direction:column;align-items:flex-start;gap:8px}
  .dash-title{font-size:18px}
  .dash-header>div:last-child{width:100%;display:flex;gap:6px}
  .dash-header>div:last-child .btn{flex:1;font-size:11px;padding:8px 6px}
  .url-box{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 12px}
  .url-box-link{font-size:12px;word-break:break-all}

  /* ── STATS ── */
  .stats-row{grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:8px}
  .stat-card{padding:10px 10px}
  .stat-val{font-size:22px}
  .stat-val.stat-val-text{font-size:14px;letter-spacing:-.2px}
  .stat-lbl{font-size:9px}

  /* ── TABS ── */
  .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .tabs::-webkit-scrollbar{display:none}
  .tab-btn{font-size:10px;padding:10px 8px;white-space:nowrap;min-width:52px}
  .tab-pane{max-height:none;padding:12px 10px}

  /* ── EDITOR ── */
  .editor-layout{grid-template-columns:1fr}
  .phone-wrap{position:static;display:flex;justify-content:center;padding:16px 0}
  .phone-wrap::before{display:none}
  .editor-card{border-radius:12px}

  /* ── FORMS ── */
  .two-col{grid-template-columns:1fr}
  .custom-url-row{grid-template-columns:1fr 1fr auto;gap:4px}

  /* ── PLATFORM GRID ── */
  .platform-grid{grid-template-columns:repeat(3,1fr);max-height:190px}

  /* ── BG SWATCHES ── */
  .bg-grid{grid-template-columns:repeat(4,1fr)}

  /* ── AVATAR ── */
  .avatar-upload-wrap{gap:10px}
  .avatar-preview{width:56px;height:56px}

  /* ── PLANS ── */
  .plans-grid{grid-template-columns:1fr;gap:10px}
  .plan-popular{font-size:8px;padding:2px 10px}

  /* ── CYCLE TOGGLE ── */
  .cycle-toggle{gap:8px}
  .cycle-label{font-size:12px}

  /* ── ANALYTICS ── */
  .an-summary{grid-template-columns:repeat(3,1fr);gap:6px}
  .an-sum-card{padding:10px 4px}
  .an-sum-val{font-size:16px}
  .an-sum-lbl{font-size:8px}
  .an-period-btn{font-size:11px;padding:4px 9px}
  .an-period-row{gap:4px}
  .an-custom-row{gap:6px}
  .an-custom-row input[type=date]{min-width:90px;font-size:11px;padding:5px 6px}

  /* ── BANNER MODE BTNS ── */
  .banner-toggle-row{flex-wrap:wrap}
  .bmode-btn{font-size:11px;padding:7px 4px}

  /* ── LINK ITEMS ── */
  .link-item{gap:5px;padding:8px 8px}
  .link-inputs{flex-direction:column;gap:4px}
  .link-inputs input{font-size:11px}

  /* ── MODALS ── */
  .modal-box{
    width:calc(100vw - 24px);
    max-width:100%;
    padding:20px 16px;
    border-radius:16px;
    max-height:90vh;
    overflow-y:auto;
  }
  .modal-footer{flex-direction:column;gap:6px}
  .modal-footer .btn{width:100%}

  /* ── TOAST ── */
  #toast{font-size:12px;padding:10px 20px;white-space:normal;max-width:calc(100vw - 32px);text-align:center}

  /* ── ADMIN ── */
  .admin-shell{flex-direction:column;height:auto;min-height:100vh}
  .admin-sidebar{
    width:100%;
    height:auto;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    box-shadow:none;
    border-bottom:2px solid rgba(255,255,255,.08);
  }
  .admin-sidebar::-webkit-scrollbar{display:none}
  .admin-sidebar-brand{display:none}
  .a-nav{display:flex;flex-direction:row;padding:0;overflow-x:auto;flex:1}
  .a-nav-item{
    border-left:none;
    border-bottom:3px solid transparent;
    padding:12px 14px;
    font-size:11px;
    white-space:nowrap;
    flex-shrink:0;
    gap:6px;
  }
  .a-nav-item.on{border-left-color:transparent;border-bottom-color:#e8824a}
  .a-nav-item.on::before{display:none}
  .admin-content{max-height:none;overflow-y:visible}
  .a-sec{padding:14px 12px}
  .a-page-title{font-size:16px}
  .table-wrap{border-radius:10px}
  .tbl{min-width:500px}
  .tbl th,.tbl td{padding:8px 10px;font-size:12px}

  /* ── PUBLIC PROFILE ── */
  .pub-profile{padding:14px}
  .pub-inner{max-width:100%}

  /* ── THEME GRID ── */
  .theme-grid-v2{grid-template-columns:1fr 1fr}

  /* ── COLOR SECTION ── */
  .color-picker-row{gap:8px}
  .color-section-card{padding:12px 10px}

  /* ── LANG DROPDOWN ── */
  .lang-dropdown{min-width:160px}
}