@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=Inter:wght@400;500;600;700&display=swap');
:root{
  --bg:#070b16; --bg2:#0b1024; --panel:#0f1630; --panel2:#15203f; --line:#243156;
  --fg:#eaf0ff; --mut:#8c9cc6; --dim:#586691;
  --brand:#7c5cff; --brand2:#22d3ee; --branddim:#191e46;
  --blue:#3b82f6; --green:#22c55e; --purple:#a855f7; --pink:#f43f7e; --yellow:#eab308;
  --radius:14px; --shadow:0 12px 50px rgba(4,8,30,.6);
  --glow:0 0 24px rgba(124,92,255,.45);
  --font:'Inter','Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  --font-head:'Space Grotesk','Inter',var(--font);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--fg);line-height:1.55;-webkit-font-smoothing:antialiased;
  background:
    radial-gradient(820px 520px at 10% -10%,rgba(124,92,255,.16),transparent),
    radial-gradient(760px 520px at 100% 0%,rgba(34,211,238,.12),transparent),
    var(--bg);
  background-attachment:fixed}
h1,h2,h3,.brand,.amt{font-family:var(--font-head);letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
.muted{color:var(--mut)} .dim{color:var(--dim)} .small{font-size:.85rem}
.center{text-align:center}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;border:1px solid transparent;
  background:var(--panel2);color:var(--fg);padding:.6rem 1.1rem;border-radius:10px;
  font:inherit;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap}
.btn:hover{transform:translateY(-1px);filter:brightness(1.08)}
.btn:active{transform:translateY(0)}
.btn-brand{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;
  box-shadow:0 6px 20px rgba(124,92,255,.35)}
.btn-ghost{background:transparent;border-color:var(--line)}
.btn-green{background:var(--green);color:#04210f}
.btn-blue{background:var(--blue);color:#fff}
.btn-danger{background:transparent;border-color:#52262a;color:#ff8a8a}
.btn-lg{padding:.85rem 1.6rem;font-size:1.05rem}
.btn-sm{padding:.35rem .7rem;font-size:.82rem;border-radius:8px}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none}

/* ---------- chips / badges ---------- */
.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem;border-radius:999px;
  font-size:.74rem;font-weight:700;border:1px solid var(--line);background:var(--panel)}
.badge.draft{color:var(--mut)}
.badge.scheduled{color:#cdb4ff;border-color:#3a2d5a;background:#1c1630}
.badge.posted{color:#86efac;border-color:#1f4d33;background:#0e2419}
.chip{display:inline-flex;align-items:center;gap:.3rem;padding:.18rem .55rem;border-radius:8px;
  font-size:.72rem;font-weight:600;border:1px solid var(--line);background:var(--bg2);color:var(--mut);
  cursor:pointer;transition:.12s}
.chip.on{background:var(--green);color:#04210f;border-color:transparent}
.chip:hover{filter:brightness(1.1)}

/* ---------- generic cards ---------- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem}
.grid{display:grid;gap:1.1rem}
.flex{display:flex;gap:1rem;align-items:center}
.between{display:flex;justify-content:space-between;align-items:center;gap:1rem}
.wrap{flex-wrap:wrap}

/* ---------- top brand ---------- */
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:1.15rem}
.brand .logo{width:34px;height:34px}

/* ================= AUTH ================= */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:2rem;
  background:radial-gradient(900px 500px at 20% -10%,rgba(124,92,255,.18),transparent),
             radial-gradient(700px 500px at 100% 0%,rgba(59,130,246,.14),transparent),var(--bg)}
.auth-card{width:100%;max-width:430px;background:var(--panel);border:1px solid var(--line);
  border-radius:18px;padding:2.2rem;box-shadow:var(--shadow)}
.auth-card h1{font-size:1.6rem;margin:.4rem 0 .2rem}
.field{margin:.9rem 0}
.field label{display:block;font-size:.85rem;color:var(--mut);margin-bottom:.35rem;font-weight:600}
.input,textarea,select{width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--fg);
  padding:.7rem .85rem;border-radius:10px;font:inherit;transition:.15s}
.input:focus,textarea:focus,select:focus{outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px var(--branddim)}
textarea{min-height:90px;resize:vertical;font-family:ui-monospace,Consolas,monospace;font-size:.85rem}
.flash{padding:.7rem 1rem;border-radius:10px;margin:.6rem 0;font-size:.9rem}
.flash.error{background:#2a1416;color:#ffb4b4;border:1px solid #52262a}
.flash.ok{background:#0e2419;color:#86efac;border:1px solid #1f4d33}

/* ================= APP SHELL ================= */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:var(--bg2);border-right:1px solid var(--line);padding:1.1rem;position:sticky;top:0;
  height:100vh;display:flex;flex-direction:column;gap:.3rem}
.side .brand{padding:.4rem .5rem 1rem}
.nav a{display:flex;align-items:center;gap:.7rem;padding:.65rem .8rem;border-radius:10px;color:var(--mut);
  font-weight:600;transition:.12s}
.nav a:hover{background:var(--panel);color:var(--fg)}
.nav a.active{background:linear-gradient(135deg,rgba(124,92,255,.22),rgba(124,92,255,.06));
  color:#fff;border:1px solid #2c2a66}
.nav .ico{width:20px;text-align:center}
.side .grow{flex:1}
.userbox{border-top:1px solid var(--line);padding-top:.9rem;font-size:.85rem}
.userbox .avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--purple));
  display:grid;place-items:center;font-weight:800;color:#fff}

.main{padding:1.8rem 2.2rem;max-width:1200px;width:100%}
.page-head{margin-bottom:1.4rem}
.page-head h1{font-size:1.7rem}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.4rem}

/* stat cards */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;position:relative;overflow:hidden}
.stat .n{font-size:2rem;font-weight:800;line-height:1}
.stat .l{color:var(--mut);font-size:.85rem;margin-top:.3rem}
.stat .ic{position:absolute;right:1rem;top:1rem;font-size:1.4rem;opacity:.5}
.stat.brand{border-color:#2c2a66;background:linear-gradient(135deg,rgba(124,92,255,.14),var(--panel))}

/* video grid */
.vgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1.1rem}
.vcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.15s}
.vcard:hover{transform:translateY(-3px);border-color:#34465a}
.vthumb{aspect-ratio:9/16;display:grid;place-items:center;position:relative;color:#fff}
.vthumb .play{width:46px;height:46px;border-radius:50%;background:rgba(0,0,0,.45);display:grid;place-items:center;font-size:1.1rem;backdrop-filter:blur(2px)}
.vthumb .dur{position:absolute;bottom:.5rem;right:.5rem;background:rgba(0,0,0,.6);padding:.1rem .45rem;border-radius:6px;font-size:.72rem}
.vcard .body{padding:.8rem}
.vcard .t{font-size:.84rem;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em}

/* tables */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:.7rem .6rem;border-bottom:1px solid var(--line);font-size:.9rem}
th{color:var(--mut);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}

/* progress */
.bar{height:9px;background:var(--bg2);border-radius:999px;overflow:hidden;border:1px solid var(--line)}
.bar > i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--brand),var(--brand2));transition:width .4s}
.job{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1rem;margin-bottom:.8rem}

/* ================= LANDING ================= */
.lnav{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;
  padding:1rem 2.2rem;background:rgba(11,15,20,.8);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.lnav .links{display:flex;gap:1.6rem;align-items:center}
.lnav .links a{color:var(--mut);font-weight:600}.lnav .links a:hover{color:var(--fg)}
.hero{padding:6rem 2rem 4rem;text-align:center;position:relative;overflow:hidden;
  background:radial-gradient(900px 500px at 50% -20%,rgba(124,92,255,.22),transparent)}
.hero .eyebrow{display:inline-flex;gap:.5rem;align-items:center;padding:.35rem .9rem;border:1px solid var(--line);
  border-radius:999px;color:var(--brand2);font-weight:700;font-size:.82rem;background:var(--panel);margin-bottom:1.4rem}
.hero h1{font-size:clamp(2.3rem,6vw,4rem);line-height:1.05;font-weight:800;max-width:14ch;margin:0 auto 1.2rem}
.hero h1 .g{background:linear-gradient(135deg,var(--brand),var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{font-size:1.2rem;color:var(--mut);max-width:62ch;margin:0 auto 2rem}
.hero .cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.section{padding:4.5rem 2rem;max-width:1140px;margin:0 auto}
.section h2{font-size:2.2rem;text-align:center;margin-bottom:.6rem}
.section .sub{text-align:center;color:var(--mut);max-width:60ch;margin:0 auto 3rem;font-size:1.05rem}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.feature{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem}
.feature .fi{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:1.4rem;margin-bottom:1rem;
  background:linear-gradient(135deg,var(--branddim),transparent);border:1px solid #221f52}
.feature h3{font-size:1.15rem;margin-bottom:.4rem}
.feature p{color:var(--mut);font-size:.95rem}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;counter-reset:s}
.step{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;position:relative}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:-14px;left:1.2rem;width:30px;height:30px;
  border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand2));display:grid;place-items:center;font-weight:800;color:#fff}
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.price{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:2rem;position:relative}
.price.pop{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand),0 20px 50px rgba(124,92,255,.18)}
.price .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--brand),var(--brand2));
  color:#fff;font-size:.72rem;font-weight:800;padding:.25rem .8rem;border-radius:999px}
.price h3{font-size:1.2rem;color:var(--mut)}
.price .amt{font-size:2.6rem;font-weight:800;margin:.3rem 0}
.price .amt span{font-size:1rem;color:var(--mut);font-weight:600}
.price ul{list-style:none;margin:1.2rem 0;display:grid;gap:.6rem}
.price li{display:flex;gap:.6rem;color:var(--fg);font-size:.92rem}
.price li::before{content:"✓";color:var(--green);font-weight:800}
.lfoot{border-top:1px solid var(--line);padding:2.5rem;text-align:center;color:var(--dim)}

/* platform icon chips */
.chip.icon{padding:.28rem .42rem;background:var(--bg2)}
.chip.icon.on{background:rgba(34,197,94,.18);box-shadow:0 0 0 1.5px var(--green)}
.pi{width:18px;height:18px;display:block;border-radius:4px}

/* video modal */
.modal{position:fixed;inset:0;z-index:60;display:none;place-items:center;padding:2rem}
.modal-bg{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(3px)}
.modal-card{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:16px;
  padding:1.2rem;width:min(420px,92vw);box-shadow:var(--shadow)}

/* pricing toggle */
.toggle{display:inline-flex;background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:.25rem;gap:.25rem}
.toggle button{border:none;background:transparent;color:var(--mut);font:inherit;font-weight:700;padding:.4rem 1.1rem;border-radius:999px;cursor:pointer}
.toggle button.active{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff}
.save-badge{color:var(--green);font-weight:700;font-size:.8rem}
.was{color:var(--dim);text-decoration:line-through;font-size:1.1rem;font-weight:600}
.promo-note{color:var(--brand2);font-size:.8rem;font-weight:700}

/* media */
.mlist{display:grid;gap:.6rem}
.mrow{display:flex;align-items:center;gap:.9rem;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:.7rem .9rem}
.mrow .mname{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;font-size:.92rem}
.mrow audio{height:34px}
.mrow video{width:80px;border-radius:8px;background:#000}
.uploadbox{border:2px dashed var(--line);border-radius:12px;padding:1.2rem;text-align:center;color:var(--mut)}

/* mobile app shell: the sidebar becomes a hamburger-triggered full-screen menu */
.mobtop,.side-close{display:none}
@media(max-width:900px){
  html,body{overflow-x:hidden}
  .shell{grid-template-columns:1fr}
  .mobtop{display:flex;align-items:center;justify-content:space-between;
    padding:.6rem 1rem;position:sticky;top:0;z-index:40;
    background:var(--bg2);border-bottom:1px solid var(--line)}
  .mobtop-btn{background:transparent;border:1px solid var(--line);color:var(--fg);
    font-size:1.25rem;line-height:1;padding:.25rem .6rem;border-radius:9px;cursor:pointer}
  .side{display:none}
  .side.open{display:flex;position:fixed;inset:0;z-index:50;height:100vh;
    flex-direction:column;overflow-y:auto;padding:1.2rem}
  .side-close{display:block;position:absolute;top:1rem;right:1rem;background:transparent;
    border:none;color:var(--fg);font-size:1.5rem;line-height:1;cursor:pointer}
  body.nav-open{overflow:hidden}
  .nav a{font-size:1.05rem;padding:.8rem .9rem}
  .main{padding:1.1rem .9rem;min-height:auto}
  .main .grid{grid-template-columns:1fr!important}      /* collapse every page grid */
  .stats,.features,.steps,.pricing{grid-template-columns:1fr 1fr}
  .topbar{flex-wrap:wrap;gap:.6rem}
  input[type=file]{max-width:100%}
  /* wide admin users table -> one card per user (label : value rows) */
  table.admin-users thead{display:none}
  table.admin-users, table.admin-users tbody, table.admin-users tr, table.admin-users td{display:block;width:100%}
  table.admin-users tr{background:var(--panel);border:1px solid var(--line);border-radius:12px;
    margin-bottom:.8rem;padding:.3rem .2rem}
  table.admin-users td{border:none;display:flex;justify-content:space-between;align-items:center;
    gap:1rem;padding:.45rem .8rem;font-size:.9rem}
  table.admin-users td::before{content:attr(data-label);color:var(--mut);font-size:.74rem;
    font-weight:700;text-transform:uppercase;letter-spacing:.04em;flex:none}
}
@media(max-width:600px){.stats,.features,.steps,.pricing{grid-template-columns:1fr}}

/* --- register captcha / robot check --- */
.robotbox{border:1px solid var(--line);border-radius:12px;padding:.85rem 1rem;margin:.5rem 0 .2rem;
  background:var(--bg2);display:flex;flex-direction:column;gap:.7rem}
.robot-check{display:flex;align-items:center;gap:.6rem;cursor:pointer;font-weight:600}
.robot-check input{width:20px;height:20px;accent-color:var(--brand)}
.captcha-q{display:flex;align-items:center;gap:.7rem;color:var(--mut);font-weight:600}

/* --- legal pages --- */
.legal h3{margin:1.7rem 0 .4rem;font-size:1.12rem}
.legal p{margin-bottom:.5rem}
.legal a{text-decoration:underline}

/* --- futuristic polish --- */
.auth-card{box-shadow:var(--shadow),0 0 70px rgba(124,92,255,.14)}
.auth-card::before{content:"";position:absolute;inset:0;border-radius:18px;padding:1px;pointer-events:none;
  background:linear-gradient(135deg,rgba(124,92,255,.6),rgba(34,211,238,.35),transparent 60%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude}
.auth-card{position:relative}
.btn-brand{box-shadow:0 8px 26px rgba(124,92,255,.4)}
.price.pop{box-shadow:0 0 0 1px var(--brand),0 24px 60px rgba(124,92,255,.22)}
.hero .eyebrow{box-shadow:0 0 30px rgba(124,92,255,.2)}

/* --- form validation styling --- */
.input.bad{border-color:#ff5b6e;box-shadow:0 0 0 3px rgba(255,91,110,.18)}
.ferr{color:#ff8a92;font-size:.82rem;margin-top:.35rem;font-weight:600}
.req-x{color:#ff5b6e;font-weight:900;margin-left:.25rem}
.pwlist{list-style:none;padding:0;margin:.6rem 0 0;display:grid;gap:.25rem}
.pwlist li{font-size:.82rem;color:var(--mut);display:flex;align-items:center;gap:.5rem}
.pwlist li::before{content:"○";display:inline-block;color:var(--dim);font-weight:900;width:1em}
.pwlist li.ok{color:#86efac}
.pwlist li.ok::before{content:"✓";color:var(--green)}

/* --- ensure landing "Start free" button has white text everywhere --- */
.lnav .btn-brand,.lnav .btn-brand:visited{color:#fff !important}

/* --- media library: two equal-height columns, internal scrollbars --- */
.media-grid{grid-template-columns:1fr 1fr;align-items:stretch}
.media-card{display:flex;flex-direction:column;height:calc(100vh - 200px);min-height:480px}
.media-card .mlist{margin-top:.8rem}
.scroll-pane{flex:1;overflow-y:auto;padding-right:.4rem;display:grid;gap:.6rem;align-content:start}
.scroll-pane::-webkit-scrollbar{width:10px}
.scroll-pane::-webkit-scrollbar-track{background:transparent}
.scroll-pane::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.scroll-pane::-webkit-scrollbar-thumb:hover{background:var(--panel2)}
@media(max-width:900px){.media-grid{grid-template-columns:1fr}.media-card{height:auto;max-height:60vh}}

/* --- profile avatar + sidebar avatar image --- */
.userbox .avatar{overflow:hidden}
.userbox .avatar img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}
.userlink:hover .avatar{filter:brightness(1.1)}
.avatar-big{width:140px;height:140px;border-radius:50%;display:grid;place-items:center;color:#fff;
  font-size:3rem;font-weight:800;margin:.2rem auto 0;overflow:hidden;box-shadow:0 0 30px rgba(124,92,255,.35)}
.avatar-big img{width:100%;height:100%;object-fit:cover}

/* --- app footer (logged-in shell) --- */
.appfoot{margin-top:3rem;padding:1.4rem 0 .5rem;border-top:1px solid var(--line);
  color:var(--mut);font-size:.85rem}
.appfoot a{color:var(--mut)} .appfoot a:hover{color:var(--fg)}

/* --- show/hide password eye --- */
.pw-wrap{position:relative}
.pw-wrap input{padding-right:44px}
.pw-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;
  border:none;cursor:pointer;font-size:1.15rem;opacity:.65;line-height:1}
.pw-eye:hover{opacity:1}

/* --- library: left list + right detail panel --- */
.libsplit{display:grid;grid-template-columns:minmax(0,1fr) 600px;gap:1.2rem;align-items:start}
.liblist{display:grid;gap:.7rem}
.libcard{display:flex;gap:.9rem;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;padding:.7rem;cursor:pointer;transition:.12s}
.libcard:hover{border-color:#34465a;transform:translateY(-1px)}
.libcard.sel{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand)}
.libthumb{position:relative;width:74px;min-width:74px;height:120px;border-radius:8px;color:#fff}
.libthumb .dur{position:absolute;bottom:4px;right:4px;background:rgba(0,0,0,.6);
  padding:0 .35rem;border-radius:5px;font-size:.68rem}
.partspill{position:absolute;top:4px;left:4px;background:var(--brand);color:#fff;
  font-size:.62rem;font-weight:700;padding:.1rem .35rem;border-radius:5px}
.libmeta{min-width:0;display:flex;flex-direction:column;gap:.25rem;padding-top:.2rem}
.libmeta .t{font-weight:600;font-size:.92rem;display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden}
.libdetail{position:sticky;top:1rem}
.pager{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:1rem;align-items:center}
@media(max-width:900px){.libsplit{grid-template-columns:1fr}.libdetail{position:static}}

/* --- sticky footer: sits at the bottom of the viewport when content is short,
       and after the content (scroll to see it) when long --- */
.main{display:flex;flex-direction:column;min-height:100vh}
.main > .appfoot{margin-top:auto}
.vsample{background:var(--panel2);border:1px solid var(--line);color:var(--fg);border-radius:8px;
  cursor:pointer;padding:.55rem .7rem;font-size:.9rem;line-height:1}
.vsample:hover{filter:brightness(1.15)}

/* --- compact spacing so Studio/Credentials/Billing fit without scrolling --- */
.main{padding:1.25rem 1.9rem}
.page-head{margin-bottom:.9rem}
.page-head h1{font-size:1.5rem}
.field{margin:.5rem 0}
.field label{margin-bottom:.22rem;font-size:.82rem}
.input,textarea,select{padding:.5rem .72rem}
.card{padding:1rem}
.grid{gap:.9rem}
/* billing plan cards a touch tighter */
.price{padding:1.3rem}
.price .amt{font-size:2rem}
.price ul{margin:.8rem 0;gap:.4rem}
.price li{font-size:.86rem}

/* clickable platform-logo icons that reveal a per-platform caption */
.capicon{width:26px;height:26px;cursor:pointer;border-radius:7px;padding:3px;
  background:#0f1530;border:1px solid var(--line);opacity:.55;
  transition:opacity .15s,box-shadow .15s,transform .1s}
.capicon:hover{opacity:1;transform:translateY(-1px)}
.capicon.on{opacity:1;border-color:var(--brand);box-shadow:0 0 0 2px rgba(124,92,255,.35)}

/* risky-content warning (Library) */
.badge.risky{background:#3a2410;color:#f0b86a;border:1px solid #6b4a1a}
.riskwarn{background:#3a2410;border:1px solid #6b4a1a;color:#f0b86a;border-radius:10px;
  padding:.7rem .85rem;font-size:.85rem;line-height:1.45;margin-bottom:.9rem}

/* register agreement checkboxes */
.agree{display:flex;align-items:flex-start;gap:.5rem;margin:.4rem 0;cursor:pointer}
.agree input{margin-top:.2rem}
.agree.bad-row span{color:#ff8585}

/* Library detail: two columns side by side so it fits without scrolling */
.libcols{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;align-items:start}
@media(max-width:1080px){.libcols{grid-template-columns:1fr}}

/* Studio: tighter so the whole form fits without scrolling */
#studiogrid .card{padding:1rem 1.1rem}
#studiogrid h3{margin-bottom:.5rem}
#studiogrid .field{margin:.45rem 0}
#studiogrid .grid{gap:.6rem}
#studiogrid label{margin-bottom:.1rem}

/* ================= responsive / mobile ================= */
/* Billing has 4 plan cards: 4 across on desktop, 2 on tablet, 1 on phone.
   (A dedicated class so it isn't overridden by an inline style.) */
.pricing-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.pricing-4{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.pricing-4{grid-template-columns:1fr}}

@media(max-width:760px){
  .main{padding:1rem .9rem}
  .page-head h1{font-size:1.35rem}
  /* rows that pair text with buttons stack instead of overflowing */
  .between{flex-wrap:wrap}
  .card.between > .flex{width:100%}
  .card.between .btn{flex:1 1 auto;justify-content:center}
  .card.between form{width:100%}
  .card.between form .btn{width:100%}
  /* plan cards a touch tighter on phones */
  .price{padding:1.1rem}
  .price .amt{font-size:1.9rem}
  /* full-width primary actions are easier to tap */
  .btn-lg{width:100%;justify-content:center}
}

/* landing page on phones: nav fits, sections breathe, nothing scrolls sideways */
@media(max-width:760px){
  html,body{overflow-x:hidden}
  .lnav{padding:.7rem 1rem;gap:.5rem}
  .lnav .brand{font-size:1.05rem}
  .lnav .links{gap:.7rem}
  .lnav .links a[href^="#"]{display:none}   /* hide section anchors (Features/How it works/Pricing) */
  .hero{padding:3.4rem 1.1rem 2.4rem}
  .hero p{font-size:1.05rem}
  .hero .cta .btn-lg{width:100%}
  .section{padding:3rem 1.1rem}
  .section h2{font-size:1.7rem}
  .section .sub{margin-bottom:2rem}
  .lfoot{padding:2rem 1.1rem}
}
