/* ============================================
   Retwinkle AI — Warm, inviting editorial theme
   ============================================ */
:root {
    --bg-primary:    #0A0812;
    --bg-secondary:  #100E18;
    --bg-card:       #151322;
    --bg-card-hover: #1A1728;
    --bg-input:      #110F18;
    --accent:        #9B93E8;
    --accent-light:  #C4B9F4;
    --accent-dark:   #7268C9;
    --accent-glow:   rgba(155,147,232,0.22);
    --champagne:     #D4C9BC;
    --green:         #3DD4B0;
    --green-glow:    rgba(61,212,176,0.14);
    --gold:          #DEB896;
    --gold-glow:     rgba(222,184,150,0.14);
    --orange:        #EDAB7A;
    --red:           #E88888;
    --blue:          #7CB0F0;
    --violet:        #B898F0;
    --teal:          #5DD4C8;
    --pink:          #F098C8;
    --text-primary:  #F2F0FA;
    --text-secondary:#B8B4CC;
    --text-muted:    #787392;
    --border:        rgba(184,172,238,0.12);
    --border-light:  rgba(200,190,240,0.18);
    --gradient-accent: linear-gradient(145deg,#8B82E0 0%,#B4A8F0 42%,#D8C0E8 100%);
    --gradient-green:  linear-gradient(145deg,#3DD4B0 0%,#26B894 100%);
    --gradient-gold:   linear-gradient(145deg,#DEB896 0%,#CEA882 100%);
    --gradient-hero:   linear-gradient(125deg,#E8D8F8 0%,#B8ACEE 35%,#E8C8D8 65%,#F0D8C8 100%);
    --shadow:      0 4px 24px rgba(8,4,24,.35),0 16px 48px rgba(6,2,20,.2);
    --shadow-lg:   0 8px 40px rgba(8,4,28,.4),0 24px 56px rgba(10,6,32,.18);
    --shadow-card: 0 1px 0 rgba(255,255,255,.05) inset,0 12px 40px rgba(8,4,24,.28);
    --radius:    16px;
    --radius-lg: 22px;
    --radius-xl: 30px;
    --font: 'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
    --font-display: 'Plus Jakarta Sans',var(--font);
    --font-elegant: 'Cormorant Garamond',Georgia,'Times New Roman',serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);line-height:1.68;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;background-image:
        radial-gradient(ellipse 130% 95% at 50% -28%,rgba(155,147,232,.14),transparent 55%),
        radial-gradient(ellipse 75% 60% at 100% 35%,rgba(200,160,220,.07),transparent 52%),
        radial-gradient(ellipse 70% 50% at 0% 75%,rgba(61,212,176,.06),transparent 55%),
        radial-gradient(ellipse 90% 45% at 50% 105%,rgba(232,180,200,.06),transparent 58%);
    background-attachment:fixed}
h3,h4,h5,h6,.navbar-brand,.feature-card h5,.tool-card h6{font-family:var(--font-display)}
.hero h1,.section-title,.cta-section .section-title,.auth-card h2{font-family:var(--font-elegant);font-weight:600;letter-spacing:-0.02em}
main.page-home{padding-bottom:0}
a{color:var(--accent-light);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent)}
::selection{background:var(--accent);color:#fff}

.fw-600{font-weight:600}.fw-700{font-weight:700}.fw-800{font-weight:800}
.gradient-text{background:var(--gradient-hero);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-label{display:inline-block;font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--champagne);margin-bottom:.85rem;font-family:var(--font-display);opacity:.95}
.section-title{font-size:clamp(2rem,4.2vw,2.95rem);font-weight:600;letter-spacing:-.03em;line-height:1.1;margin-bottom:1.15rem}
.section-sub{font-size:1.09rem;color:var(--text-secondary);max-width:34rem;margin:0 auto;line-height:1.82;font-weight:400}
/** Heading stack for sections — avoids double spacing with .mb-5 wrappers */
.section-head{max-width:36rem;margin-left:auto;margin-right:auto;margin-bottom:2.5rem}
.section-head .section-sub{margin-bottom:0}
.text-center.mb-5 .section-sub{margin-bottom:0}
.section-divider{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:0}

.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:10000;padding:.75rem 1.25rem;background:var(--accent);color:#fff!important;font-weight:600;border-radius:8px}
.skip-link:focus{position:fixed;left:1rem;top:1rem;width:auto;height:auto;outline:2px solid #fff;outline-offset:2px}

a:focus-visible,.btn:focus-visible,.nav-link:focus-visible,.theme-toggle:focus-visible,.mode-pill:focus-visible,.btn-copy:focus-visible,.btn-humanize:focus-visible,.form-control:focus-visible,.form-select:focus-visible{outline:2px solid var(--accent-light);outline-offset:2px}

/* ---------- Inner pages — consistent shell ---------- */
.text-muted{color:var(--text-secondary)!important}
.page-head{text-align:center;margin-bottom:2rem;max-width:42rem;margin-left:auto;margin-right:auto;padding-top:.25rem}
.page-head.text-start{text-align:left;max-width:none;margin-left:0;margin-right:0}
.page-kicker{display:inline-block;font-size:.62rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--champagne);margin-bottom:.65rem;font-family:var(--font-display)}
.page-title{font-family:var(--font-elegant);font-weight:600;font-size:clamp(1.85rem,3.6vw,2.45rem);letter-spacing:-.03em;line-height:1.12;margin-bottom:.65rem;color:var(--text-primary)}
.page-lead{font-size:1.0625rem;color:var(--text-secondary);line-height:1.65;margin-bottom:0;max-width:34rem;margin-left:auto;margin-right:auto;font-weight:400}
.page-hero{padding-bottom:1rem}
.tool-page-wrap{margin-bottom:2.5rem}

/* Hero icon — tool & marketing pages */
.page-tool-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.45rem;margin-left:auto;margin-right:auto;margin-bottom:.85rem;flex-shrink:0}
.page-tool-icon--accent{background:rgba(139,130,224,.12);color:var(--accent-light)}
.page-tool-icon--green{background:rgba(46,205,168,.12);color:var(--green)}
.page-tool-icon--gold{background:rgba(212,184,150,.14);color:var(--gold)}
.page-tool-icon--blue{background:rgba(107,163,232,.12);color:var(--blue)}
.page-tool-icon--violet{background:rgba(168,136,232,.12);color:var(--violet)}
.page-tool-icon--teal{background:rgba(75,196,184,.12);color:var(--teal)}
.page-tool-icon--red{background:rgba(224,112,112,.12);color:var(--red)}
.page-tool-icon--pink{background:rgba(232,136,184,.12);color:var(--pink)}
.page-tool-icon--orange{background:rgba(232,160,106,.14);color:var(--orange)}

/* Feature grid icons (tools listing) — tint only; size from .feature-icon */
.feature-icon.tint-accent{background:rgba(139,130,224,.12);color:var(--accent-light)}
.feature-icon.tint-green{background:rgba(46,205,168,.12);color:var(--green)}
.feature-icon.tint-gold{background:rgba(212,184,150,.14);color:var(--gold)}
.feature-icon.tint-blue{background:rgba(107,163,232,.12);color:var(--blue)}
.feature-icon.tint-violet{background:rgba(168,136,232,.12);color:var(--violet)}
.feature-icon.tint-teal{background:rgba(75,196,184,.12);color:var(--teal)}
.feature-icon.tint-red{background:rgba(224,112,112,.12);color:var(--red)}
.feature-icon.tint-pink{background:rgba(232,136,184,.12);color:var(--pink)}
.feature-icon.tint-orange{background:rgba(232,160,106,.14);color:var(--orange)}
.link-forward{display:inline-flex;align-items:center;gap:.25rem;color:var(--accent-light);font-size:.875rem;font-weight:600;margin-top:auto}

/* Soft badges */
.badge-soft-accent{background:rgba(139,130,224,.12)!important;color:var(--accent-light)!important;font-weight:600;font-size:.72rem;border:1px solid rgba(139,130,224,.2)}
.badge-soft-muted{background:var(--bg-secondary)!important;color:var(--text-secondary)!important;font-weight:500;font-size:.75rem}

/* Demo / editor helpers */
.badge-soft-danger{background:rgba(224,112,112,.12);color:var(--red);font-size:.7rem;border-radius:999px;padding:.28rem .65rem;font-weight:600;border:1px solid rgba(224,112,112,.22)}
.badge-soft-success{background:rgba(46,205,168,.1);color:var(--green);font-size:.7rem;border-radius:999px;padding:.28rem .65rem;font-weight:600;border:1px solid rgba(46,205,168,.2)}
.editor-textarea-min{min-height:200px}
.muted-note{font-size:.8125rem;color:var(--text-muted)}
.link-inline-accent{color:var(--accent-light);font-weight:500}
.text-accent-icon{color:var(--accent-light)}
.compare-table-wrap{max-width:900px;margin:0 auto}

/* Legal / long-form */
.prose-card{color:var(--text-secondary);line-height:1.85;font-size:.925rem}
.prose-card h5,.prose-card .h-prose{font-family:var(--font-display);font-weight:700;font-size:1rem;margin-top:1.75rem;margin-bottom:.75rem;color:var(--text-primary)}
.prose-card h5:first-child{margin-top:0}
.code-block{background:var(--bg-secondary);padding:1rem 1.15rem;border-radius:var(--radius);color:var(--text-secondary);font-size:.85rem;border:1px solid var(--border);overflow-x:auto;line-height:1.55}
.code-inline{color:var(--green);font-size:.95rem;word-break:break-all}

/* Blog cards */
.blog-card{padding:0!important;overflow:hidden}
.blog-card-thumb{height:176px;background:linear-gradient(145deg,var(--bg-secondary),var(--bg-card));overflow:hidden;border-bottom:1px solid var(--border);position:relative}
.blog-card-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.blog-card-thumb i{font-size:3rem;color:var(--accent-light);opacity:.22}
.blog-card-body{padding:1.5rem}
.blog-card-title{font-size:1.05rem;line-height:1.35;font-family:var(--font-display);font-weight:700;color:var(--text-primary);margin-bottom:.5rem}
.blog-badge-featured{background:linear-gradient(145deg,#b45309 0%,#d97706 100%);color:#fff!important;border:none;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.42em .7em;line-height:1}
.blog-badge-featured i{font-size:.55rem}
body.light-mode .blog-badge-featured{background:linear-gradient(145deg,#c2410c 0%,#ea580c 100%);box-shadow:0 2px 8px rgba(234,88,12,.22)}

/* Blog article (single post) */
.blog-post-page__thumb-img{display:block;width:100%;height:clamp(180px,32vw,400px);object-fit:cover}
.blog-post-body{font-size:.95rem;line-height:1.8}
.blog-post-body p{margin-bottom:1rem}
.blog-post-body p:last-child{margin-bottom:0}
.blog-post-body strong{color:var(--text-primary)}
body.light-mode .blog-post-body strong{color:var(--text-primary)}

/* Chat */
.chat-window-scroll{height:400px;overflow-y:auto;padding:1.5rem}
.chat-row{display:flex;margin-bottom:1rem;align-items:flex-start}
.chat-row--user{justify-content:flex-end}
.chat-avatar{width:36px;height:36px;background:rgba(139,130,224,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:10px;color:var(--accent-light);border:1px solid var(--border)}
.chat-bubble-ai{background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px 16px 16px 16px;padding:12px 16px;max-width:80%;font-size:.9rem;color:var(--text-secondary);line-height:1.7}
.chat-bubble-user{background:var(--accent);color:#fff;border-radius:16px 6px 16px 16px;padding:12px 16px;max-width:80%;font-size:.9rem;box-shadow:0 1px 0 rgba(255,255,255,.1) inset}

body.light-mode .chat-bubble-ai{background:var(--bg-input);border-color:var(--border)}
body.light-mode .chat-avatar{background:rgba(139,130,224,.1)}
.small-prompt-chip{font-size:.75rem}
.success-check-wrap{width:80px;height:80px;background:rgba(46,205,168,.12);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin-bottom:1.5rem;border:1px solid rgba(46,205,168,.22)}
.success-check-wrap i{font-size:2.5rem;color:var(--green)}

/* NAVBAR */
.navbar{background:rgba(10,8,18,.82)!important;backdrop-filter:blur(32px) saturate(160%);-webkit-backdrop-filter:blur(32px) saturate(160%);border-bottom:1px solid rgba(184,172,238,.1);padding:1rem 0;transition:background .35s, border-color .35s;box-shadow:0 1px 0 rgba(255,255,255,.03)}
.navbar-brand{font-weight:700;font-size:1.2rem;color:#fff!important;letter-spacing:-.02em;display:flex;align-items:center;gap:.55rem}
.navbar-brand .brand-icon{width:34px;height:34px;background:var(--gradient-accent);border-radius:11px;display:inline-flex;align-items:center;justify-content:center;font-size:.9rem;color:#fff!important;box-shadow:0 1px 0 rgba(255,255,255,.12) inset,0 4px 20px var(--accent-glow)}
.navbar-brand .brand-icon i{color:#fff!important}
.navbar-brand .brand-wordmark{font-weight:800;color:#fff!important}
.navbar-brand .brand-wordmark > span{color:var(--accent-light)!important}
.navbar .nav-link{color:var(--text-secondary)!important;font-weight:500;font-size:.8125rem;padding:.5rem .85rem!important;border-radius:10px;transition:color .2s,background .2s}
.navbar .nav-link:hover{color:var(--text-primary)!important;background:rgba(155,147,232,.1)}
.navbar .nav-link.active{color:var(--accent-light)!important}
.dropdown-menu{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:.5rem}
.dropdown-item{color:var(--text-secondary);border-radius:8px;padding:.5rem .75rem;font-size:.875rem;transition:all .15s}
.dropdown-item:hover{background:rgba(139,130,224,.08);color:var(--text-primary)}
.dropdown-divider{border-color:var(--border);margin:.35rem 0}
.btn-nav-cta{background:var(--gradient-accent);color:#fff!important;border:none;border-radius:999px;padding:.48rem 1.15rem;font-weight:600;font-size:.8125rem;transition:box-shadow .25s,transform .2s,filter .2s;white-space:nowrap;box-shadow:0 1px 0 rgba(255,255,255,.12) inset}
.btn-nav-cta:hover{transform:translateY(-1px);box-shadow:0 1px 0 rgba(255,255,255,.15) inset,0 8px 28px var(--accent-glow);color:#fff!important;filter:brightness(1.03)}
.navbar .btn-outline-light,.navbar .btn-nav-cta{justify-content:center;text-align:center}

/* Tools mega menu — static display (no Popper) so we can center under “Tools” */
.navbar .mega-nav-item.dropdown{position:relative}
.navbar .mega-nav-item .mega-menu.dropdown-menu{
    padding:0;
    background:var(--bg-card);
    border:1px solid var(--border);
}
@media(min-width:992px){
    .navbar .mega-nav-item .mega-menu.dropdown-menu{
        min-width:min(920px,calc(100vw - 2.5rem));
        max-width:960px;
        border-radius:var(--radius-lg);
        margin-top:.5rem!important;
        box-shadow:var(--shadow-lg)!important;
        /* Center wide panel on the Tools nav item */
        left:50%!important;
        right:auto!important;
        transform:translateX(-50%)!important;
    }
}
.mega-menu-inner{max-width:none}
.mega-menu-all{
    text-decoration:none;
    background:rgba(139,130,224,.08);
    border:1px solid rgba(139,130,224,.2);
    color:var(--text-primary);
    transition:background .2s,border-color .2s,transform .2s;
}
.mega-menu-all:hover{
    background:rgba(139,130,224,.12);
    border-color:rgba(139,130,224,.32);
    color:var(--text-primary);
}
.mega-menu-all-icon{
    width:44px;height:44px;border-radius:12px;
    background:var(--gradient-accent);
    color:#fff!important;
    display:flex;align-items:center;justify-content:center;
    font-size:1.15rem;
    flex-shrink:0;
    box-shadow:0 1px 0 rgba(255,255,255,.12) inset;
}
.mega-menu-all-title{display:block;font-weight:700;font-size:.95rem;font-family:var(--font-display)}
.mega-menu-all-desc{display:block;font-size:.78rem;color:var(--text-muted);margin-top:.15rem}
.mega-menu-all-arrow{color:var(--accent-light);font-size:1.1rem}
.mega-menu-heading{
    font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
    color:var(--champagne);margin-bottom:.85rem;font-family:var(--font-display);
}
.mega-menu-list li+li{margin-top:.15rem}
.mega-menu-link{
    padding:.45rem .5rem;border-radius:10px;color:var(--text-secondary)!important;
    font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;
}
.mega-menu-link__label{min-width:0;word-break:break-word}
.mega-menu-link:hover,.mega-menu-link:focus{
    background:rgba(139,130,224,.08);
    color:var(--text-primary)!important;
}
.mega-menu-icon{
    flex-shrink:0;width:1.35rem;text-align:center;margin-top:.1rem;font-size:1rem;
}
.mega-menu-plan{
    display:inline-block;
    font-size:.58rem;
    font-weight:700;
    letter-spacing:.05em;
    text-transform:uppercase;
    border-radius:999px;
    padding:.16rem .46rem;
    line-height:1;
    border:1px solid transparent;
    flex-shrink:0;
    margin-top:.02rem;
}
.mega-menu-plan--free{background:rgba(100,116,139,.14);color:var(--text-muted);border-color:rgba(100,116,139,.25)}
.mega-menu-plan--basic{background:rgba(56,189,248,.16);color:#38bdf8;border-color:rgba(56,189,248,.35)}
.mega-menu-plan--pro{background:rgba(245,158,11,.16);color:#f59e0b;border-color:rgba(245,158,11,.35)}
@media(max-width:991px){
    .navbar .mega-nav-item .mega-menu.dropdown-menu{
        min-width:min(100%,100vw - 2rem);
        max-height:min(72vh,560px);
        overflow-y:auto;
        margin-top:.35rem!important;
        border-radius:var(--radius-lg);
        border:1px solid var(--border);
        background:var(--bg-card);
        padding:0;
        box-shadow:var(--shadow-lg)!important;
        left:0!important;
        transform:none!important;
        max-width:none;
    }
    .mega-menu-inner{padding-left:1rem!important;padding-right:1rem!important}
}
body.light-mode .mega-menu-all{background:rgba(139,130,224,.06);border-color:rgba(139,130,224,.18)}
body.light-mode .mega-menu-all:hover{background:rgba(139,130,224,.1)}

/* HERO */
.hero{padding:clamp(4.25rem,12vw,8rem) 0 clamp(3.25rem,8vw,5.75rem);text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-32%;left:50%;transform:translateX(-50%);width:min(1100px,96vw);height:720px;background:radial-gradient(ellipse at center,rgba(155,147,232,.2) 0%,rgba(216,180,220,.08) 38%,transparent 68%);pointer-events:none;z-index:0}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(184,172,238,.2),transparent)}
.hero>*{position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:.55rem;background:linear-gradient(135deg,rgba(155,147,232,.12),rgba(232,200,210,.06));border:1px solid rgba(184,172,238,.28);border-radius:999px;padding:.48rem 1.2rem;font-size:.78rem;color:var(--text-secondary);font-weight:500;font-family:var(--font-display);margin-bottom:1.9rem;letter-spacing:.03em;animation:fadeUp .5s ease both;box-shadow:0 4px 24px rgba(10,4,28,.15)}
.hero-badge .badge-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 12px rgba(61,212,176,.6);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.75;transform:scale(1.15)}}
.hero h1{font-size:clamp(2.65rem,6vw,4.25rem);font-weight:600;line-height:1.04;margin-bottom:1.45rem;letter-spacing:-.035em;animation:fadeUp .5s .1s ease both}
.hero p{font-size:1.14rem;color:var(--text-secondary);max-width:36rem;margin:0 auto 2.45rem;line-height:1.82;font-weight:400;animation:fadeUp .5s .2s ease both}
.hero-cta{animation:fadeUp .5s .3s ease both;gap:1rem!important}
.hero-note{font-size:.84rem;color:var(--text-muted);margin-top:1.25rem;animation:fadeUp .5s .4s ease both}

/* Home — soft bands between hero and body content */
/* Trust marquee (home) */
main.page-home .trust-marquee-section{
    margin-left:clamp(.25rem,2vw,.75rem);margin-right:clamp(.25rem,2vw,.75rem);
    border-radius:var(--radius-xl);
}
body.light-mode main.page-home .trust-marquee-section{
    background:#f4f4f7;
}
body:not(.light-mode) main.page-home .trust-marquee-section{
    background:rgba(255,255,255,.04);
    border:1px solid rgba(184,172,238,.1);
}
main.page-home .trust-marquee-section .section-head{max-width:46rem;margin-bottom:1.75rem}
.trust-marquee__viewport{
    overflow:hidden;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
    mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
}
.trust-marquee__track{
    display:flex;
    width:max-content;
    animation:trust-marquee-scroll 48s linear infinite;
}
@keyframes trust-marquee-scroll{
    from{transform:translateX(0)}
    to{transform:translateX(-50%)}
}
.trust-marquee__list{
    display:flex;
    align-items:center;
    gap:clamp(2.25rem,5vw,3.75rem);
    list-style:none;
    margin:0;
    padding:0 1.5rem;
    flex-shrink:0;
}
.trust-marquee__item{
    flex-shrink:0;
    font-size:clamp(.88rem,1.5vw,.98rem);
    font-weight:600;
    color:#333;
    white-space:nowrap;
    font-family:var(--font-display);
    letter-spacing:.02em;
}
body:not(.light-mode) .trust-marquee-section{
    background:rgba(255,255,255,.04);
    border:1px solid rgba(184,172,238,.1);
}
body:not(.light-mode) .trust-marquee__item{color:#a8a4bc}
@media (prefers-reduced-motion:reduce){
    .trust-marquee__track{animation:none;flex-wrap:wrap;justify-content:center;width:100%;max-width:960px;margin:0 auto}
    .trust-marquee__list[aria-hidden="true"]{display:none}
    .trust-marquee__viewport{-webkit-mask-image:none;mask-image:none}
}
main.page-home .home-strip--stats .stats-counter{margin-left:auto;margin-right:auto;max-width:900px}

/* BUTTONS */
.btn-primary{background:var(--gradient-accent);border:none;border-radius:999px;padding:.82rem 1.95rem;font-weight:600;font-size:.95rem;color:#fff;transition:transform .2s,box-shadow .28s,filter .2s;display:inline-flex;align-items:center;justify-content:center;text-align:center;gap:.55rem;box-shadow:0 1px 0 rgba(255,255,255,.14) inset,0 8px 28px rgba(88,72,180,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 14px 40px rgba(139,130,224,.45);color:#fff;filter:brightness(1.03)}
.btn-primary:active{transform:translateY(0)}
.btn-lg{border-radius:999px;padding:.88rem 1.95rem;font-weight:600;font-size:.975rem;letter-spacing:-.01em}
.btn-outline-light {
    border: 1px solid rgba(184, 172, 238, .35);
    border-radius: 999px;
    padding: 0.4rem 1.95rem;
    color: var(--text-primary);
    font-weight: 500;
    background: rgba(255, 255, 255, .04);
    transition: background .2s, border-color .2s, transform .2s;
    display: inline-flex;
    align-items: center;
    gap: .55rem;
}
.btn-outline-light:hover{background:rgba(155,147,232,.12);border-color:rgba(196,185,244,.55);color:#fff;transform:translateY(-1px)}
.btn-success{background:var(--gradient-green);border:none;border-radius:10px;font-weight:600;color:#fff;transition:all .25s}
.btn-success:hover{box-shadow:0 8px 30px var(--green-glow);filter:brightness(1.08);color:#fff}

/* CARDS */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color .25s,box-shadow .25s;box-shadow:var(--shadow-card)}
.card:hover{border-color:var(--border-light)}
.table{--bs-table-bg:transparent;--bs-table-accent-bg:transparent;--bs-table-color:var(--text-primary);--bs-table-border-color:var(--border);color:var(--text-primary)}
.table>thead>tr>th,.table>tbody>tr>td{background:transparent!important;border-color:var(--border)!important}

/* FEATURE CARDS */
.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.1rem 2.15rem;transition:border-color .35s,transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s;height:100%;position:relative;overflow:hidden;box-shadow:var(--shadow-card)}
.feature-card::before{content:'';position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at 50% 0%,rgba(155,147,232,.12) 0%,transparent 62%);opacity:0;transition:opacity .35s;pointer-events:none}
.feature-card:hover{border-color:rgba(196,185,244,.35);transform:translateY(-4px);box-shadow:0 2px 0 rgba(255,255,255,.04) inset,0 22px 52px rgba(12,8,32,.35)}
.feature-card:hover::before{opacity:1}
.feature-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:1.1rem;flex-shrink:0}
.feature-card h5{font-weight:700;font-size:1rem;margin-bottom:.5rem;color:var(--text-primary)}
.feature-card p{color:var(--text-secondary);font-size:.875rem;margin:0;line-height:1.65}

/* TOOL CARDS */
.tool-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem 1.9rem;transition:border-color .35s,transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s;height:100%;display:flex;flex-direction:column;position:relative;box-shadow:var(--shadow-card)}
.tool-card:hover{border-color:rgba(196,185,244,.38);transform:translateY(-4px);box-shadow:0 2px 0 rgba(255,255,255,.04) inset,0 18px 46px rgba(12,8,28,.32)}
.tool-card .tool-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1rem}
.tool-card h6{font-weight:700;font-size:.95rem;margin-bottom:.4rem;color:var(--text-primary)}
.tool-card p{color:var(--text-secondary);font-size:.82rem;line-height:1.6;flex:1;margin-bottom:1rem}
.tool-card .tool-link{font-size:.82rem;font-weight:600;color:var(--accent-light);display:inline-flex;align-items:center;gap:.3rem;transition:gap .2s}
.tool-card:hover .tool-link{gap:.5rem}
.tool-badge{position:absolute;top:1rem;right:1rem;font-size:.65rem;font-weight:700;padding:.2rem .6rem;border-radius:50px;letter-spacing:.06em;text-transform:uppercase}
.tool-badge-popular{background:rgba(139,130,224,.12);color:var(--accent-light);border:1px solid rgba(139,130,224,.22)}
.tool-badge-new{background:rgba(0,210,160,.15);color:var(--green);border:1px solid rgba(0,210,160,.3)}
.tool-plan-badge{
    position:absolute;top:1rem;left:1rem;font-size:.62rem;font-weight:700;padding:.22rem .56rem;border-radius:999px;
    letter-spacing:.05em;text-transform:uppercase;border:1px solid transparent;line-height:1;
}
.tool-plan-badge--free{background:rgba(100,116,139,.14);color:var(--text-secondary);border-color:rgba(100,116,139,.3)}
.tool-plan-badge--basic{background:rgba(56,189,248,.14);color:#38bdf8;border-color:rgba(56,189,248,.35)}
.tool-plan-badge--pro{background:rgba(245,158,11,.14);color:#f59e0b;border-color:rgba(245,158,11,.35)}

/* Tool highlight cards (home) */
.tool-highlight-card{
    background:var(--bg-card);
    border:1px solid var(--border);
    border-radius:var(--radius-xl);
    padding:1.6rem 1.55rem;
    box-shadow:var(--shadow-card);
    display:flex;
    flex-direction:column;
    gap:.8rem;
}
.tool-highlight-thumb-wrap{
    width:100%;
    aspect-ratio:16/9;
    border-radius:12px;
    overflow:hidden;
    border:1px solid rgba(255,255,255,.06);
    background:rgba(255,255,255,.03);
}
.tool-highlight-thumb{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
.tool-highlight-head{display:flex;align-items:center;gap:.9rem}
.tool-highlight-icon{
    width:48px;height:48px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    font-size:1.35rem;flex-shrink:0;
}
.tool-highlight-head h3{
    margin:0;
    font-size:1.2rem;
    font-family:var(--font-display);
    font-weight:700;
    color:var(--text-primary);
}
.tool-highlight-desc{margin:0;color:var(--text-secondary);line-height:1.72;font-size:.92rem}
.tool-highlight-list{list-style:none;padding:0;margin:0;display:grid;gap:.4rem}
.tool-highlight-list li{display:flex;align-items:center;gap:.45rem;font-size:.84rem;color:var(--text-secondary)}
.tool-highlight-list i{color:var(--green)}
.tool-highlight-link{
    margin-top:auto;
    font-size:.85rem;
    font-weight:700;
    color:var(--accent-light);
    display:inline-flex;
    align-items:center;
    gap:.35rem;
    transition:gap .2s ease;
}
.tool-highlight-card:hover .tool-highlight-link{gap:.55rem}

/* PRICING CARDS */
.pricing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem 2rem;text-align:center;transition:border-color .35s,transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s;position:relative;height:100%;display:flex;flex-direction:column;box-shadow:var(--shadow-card)}
.pricing-card:hover{border-color:rgba(139,130,224,.35);transform:translateY(-3px);box-shadow:0 2px 0 rgba(255,255,255,.03) inset,0 20px 52px rgba(0,0,0,.26)}
.pricing-billing-toggle{display:flex;gap:.5rem;justify-content:center;align-items:center}
.pricing-billing-toggle__btn{border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);border-radius:999px;padding:.42rem .9rem;font-size:.8rem;font-weight:600}
.pricing-billing-toggle__btn.is-active{background:var(--gradient-accent);border-color:transparent;color:#fff}
.pricing-billing-toggle__save{margin-left:.35rem;font-size:.68rem;opacity:.95}
.pricing-card.popular{border-color:rgba(139,130,224,.45);background:linear-gradient(180deg,rgba(139,130,224,.07) 0%,var(--bg-card) 42%);box-shadow:0 0 0 1px rgba(139,130,224,.35),0 20px 52px rgba(0,0,0,.22)}
.pricing-card.popular::before{content:'MOST POPULAR';position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gradient-accent);color:#fff;font-size:.68rem;font-weight:700;padding:.3rem 1.1rem;border-radius:50px;letter-spacing:.1em;white-space:nowrap}
.pricing-name{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}
.pricing-desc{font-size:.8rem;color:var(--text-muted);margin-bottom:0}
.pricing-price{font-size:3rem;font-weight:800;line-height:1;margin:1.25rem 0 .25rem;letter-spacing:-.03em}
.pricing-price sup{font-size:1.2rem;font-weight:600;vertical-align:super;margin-right:2px}
.pricing-price span{font-size:.9rem;color:var(--text-muted);font-weight:400;letter-spacing:0}
.pricing-features{list-style:none;padding:0;margin:1.5rem 0;text-align:left;flex:1}
.pricing-features li{padding:.45rem 0;color:var(--text-secondary);font-size:.875rem;display:flex;align-items:center;gap:.6rem;border-bottom:1px solid rgba(255,255,255,.04)}
.pricing-features li:last-child{border-bottom:none}
.pricing-features li .check{color:var(--green);font-size:.9rem;flex-shrink:0}
.pricing-features li .cross{color:var(--text-muted);font-size:.9rem;flex-shrink:0}

/* EDITOR / APP */
.app-container{max-width:1100px;margin:0 auto}
.editor-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .25s,box-shadow .25s;box-shadow:var(--shadow-card)}
main.page-home .editor-panel{border-color:rgba(184,172,238,.14)}
/** Home live demo — stable grid; avoids crushed middle column at md breakpoint */
.demo-workspace{display:grid;gap:1.25rem;align-items:stretch}
.demo-pane{min-width:0}
.demo-rail{display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:.85rem;min-width:0}
.demo-mode-hint{text-align:center}
.demo-mode-hint .demo-mode-label{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.28rem}
.demo-mode-hint .demo-mode-value{font-size:.8rem;color:var(--accent-light);font-weight:600}
.demo-footnote{text-align:center;margin-top:1.35rem;font-size:.8125rem;color:var(--text-muted)}
.demo-editor-card{display:flex;flex-direction:column}
.demo-editor-card .editor-textarea{flex:1;min-height:200px;resize:vertical}
@media(min-width:992px){
    .demo-workspace{grid-template-columns:1fr minmax(152px,200px) 1fr;gap:1.5rem;align-items:stretch}
    .demo-rail{padding:.35rem 0}
}
@media(max-width:991px){
    .demo-workspace{grid-template-columns:1fr}
    .demo-pane--input{order:1}
    .demo-rail{order:2;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem 1.5rem;padding:.25rem 0}
    .demo-rail .btn-humanize{flex:1;min-width:min(100%,220px);max-width:320px}
    .demo-pane--output{order:3}
}
.editor-header{padding:.9rem 1.4rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:rgba(255,255,255,.02)}
.editor-header h6{margin:0;font-weight:600;font-size:.82rem;color:var(--text-secondary);display:flex;align-items:center;gap:.4rem}
.editor-textarea{width:100%;min-height:300px;background:transparent;border:none;color:var(--text-primary);font-size:.95rem;line-height:1.85;padding:1.4rem;resize:vertical;outline:none;font-family:var(--font)}
.editor-textarea::placeholder{color:var(--text-muted)}
.editor-footer{padding:.7rem 1.4rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:var(--text-muted);background:rgba(255,255,255,.02)}
.controls-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.4rem;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;box-shadow:var(--shadow-card)}
.onboarding-steps{
    background:var(--bg-card);
    border:1px solid var(--border);
    border-radius:12px;
    padding:.8rem .9rem;
}
.onboarding-steps__head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:.75rem;
    margin-bottom:.65rem;
    font-size:.84rem;
}
.onboarding-steps__grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:.55rem;
}
.onboarding-step{
    display:flex;
    gap:.55rem;
    align-items:flex-start;
    border:1px solid var(--border);
    background:var(--bg-secondary);
    border-radius:10px;
    padding:.55rem .62rem;
    opacity:.78;
}
.onboarding-step.is-active{opacity:1;border-color:rgba(56,189,248,.35)}
.onboarding-step.is-done{opacity:1;border-color:rgba(46,205,168,.32);background:rgba(46,205,168,.08)}
.onboarding-step__num{
    width:1.2rem;height:1.2rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;
    font-size:.66rem;font-weight:700;background:rgba(139,130,224,.14);color:var(--accent-light);flex-shrink:0;
}
.onboarding-step.is-done .onboarding-step__num{background:rgba(46,205,168,.18);color:var(--green)}
.onboarding-step__title{font-size:.76rem;font-weight:700;color:var(--text-primary)}
.onboarding-step__desc{font-size:.7rem;line-height:1.4;color:var(--text-muted)}
.app-preset-chip{font-size:.72rem}
.control-group label{display:block;font-size:.72rem;color:var(--text-muted);margin-bottom:.35rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em}
.mode-pills{display:flex;gap:.4rem;flex-wrap:wrap}
.mode-pill{padding:.38rem .9rem;border-radius:50px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}
.mode-pill:hover{border-color:var(--accent);color:var(--text-primary);background:rgba(139,130,224,.05)}
.mode-pill.active{background:var(--gradient-accent);border-color:transparent;color:#fff;box-shadow:0 2px 12px var(--accent-glow)}
.mode-pill:disabled{opacity:.3;cursor:not-allowed}
.level-slider{-webkit-appearance:none;width:130px;height:4px;border-radius:2px;background:var(--border);outline:none;cursor:pointer}
.level-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 0 3px rgba(139,130,224,.18),0 2px 10px var(--accent-glow);transition:box-shadow .2s}
.level-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 5px rgba(139,130,224,.12),0 2px 14px var(--accent-glow)}
.btn-humanize{background:var(--gradient-accent);border:none;border-radius:999px;padding:.88rem 2.5rem;font-weight:600;font-size:.975rem;color:#fff;transition:transform .2s,box-shadow .25s,filter .2s;position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;box-shadow:0 1px 0 rgba(255,255,255,.1) inset;min-height:3rem;white-space:nowrap}
.btn-humanize::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.12) 0%,transparent 55%);opacity:0;transition:opacity .3s}
.btn-humanize:hover{transform:translateY(-1px);box-shadow:0 1px 0 rgba(255,255,255,.12) inset,0 12px 40px var(--accent-glow);color:#fff}
.btn-humanize:hover::before{opacity:1}
.btn-humanize:active{transform:translateY(0)}
.btn-humanize:disabled{opacity:.5;transform:none;cursor:not-allowed;box-shadow:none}
.stats-bar{display:flex;gap:2rem;padding:1rem 0}
.stat-item{text-align:center}
.stat-value{font-size:1.5rem;font-weight:800;color:var(--accent-light)}
.stat-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.output-ready{border-color:var(--green)!important;box-shadow:0 0 0 1px var(--green),0 0 32px var(--green-glow)!important}
.btn-copy{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);padding:.38rem .8rem;font-size:.78rem;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.3rem}
.btn-copy:hover{border-color:var(--accent);color:var(--accent-light)}
.btn-copy.copied{border-color:var(--green);color:var(--green)}

/* FORMS */
.form-control,.form-select{background:var(--bg-input);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);padding:.72rem 1rem;font-size:.9rem;transition:border-color .2s,box-shadow .2s}
.form-control:focus,.form-select:focus{background:var(--bg-input);border-color:var(--accent);color:var(--text-primary);box-shadow:0 0 0 3px var(--accent-glow);outline:none}
.form-control::placeholder{color:var(--text-muted)}
.form-label{color:var(--text-secondary);font-weight:500;font-size:.85rem;margin-bottom:.4rem}
.form-select option{background:var(--bg-card)}

/* AUTH */
.auth-card{max-width:440px;margin:3rem auto;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.75rem;box-shadow:var(--shadow-lg)}
.auth-card h2{font-weight:800;text-align:center;margin-bottom:.5rem;letter-spacing:-.025em}
.auth-card .btn-primary{justify-content:center;text-align:center}

/* DASHBOARD */
.dash-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:border-color .25s}
.dash-card:hover{border-color:var(--border-light)}
.usage-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:.6rem}
.usage-bar-fill{height:100%;border-radius:3px;background:var(--gradient-accent);transition:width .6s cubic-bezier(.4,0,.2,1)}
.tool-usage-upsell{
    border:1px solid var(--border);
    background:var(--bg-card);
    border-radius:12px;
    padding:.75rem .9rem;
}
.tool-usage-upsell__head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:.8rem;
    font-size:.86rem;
    color:var(--text-secondary);
}
.tool-usage-upsell__cta{
    color:var(--accent-light);
    font-weight:700;
    text-decoration:none;
}
.tool-usage-upsell__meta{
    margin-top:.4rem;
    font-size:.74rem;
    color:var(--text-muted);
}
.tool-usage-upsell--warning{border-color:rgba(245,158,11,.35)}
.tool-usage-upsell--danger{border-color:rgba(239,68,68,.4)}
.tool-upsell-teasers{
    border:1px solid var(--border);
    border-radius:12px;
    background:var(--bg-card);
    padding:.75rem .8rem;
}
.tool-upsell-teasers__head{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:.75rem;
    margin-bottom:.65rem;
    font-size:.82rem;
}
.tool-upsell-teasers__head a{color:var(--accent-light);font-weight:700;text-decoration:none}
.tool-upsell-teasers__grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:.6rem;
}
.tool-upsell-teasers__card{
    border:1px solid var(--border);
    border-radius:10px;
    background:var(--bg-secondary);
    padding:.65rem .7rem;
    text-decoration:none;
    color:inherit;
    display:flex;
    flex-direction:column;
    gap:.33rem;
}
.tool-upsell-teasers__card:hover{border-color:var(--border-light)}
.tool-upsell-teasers__plan{
    align-self:flex-start;
    font-size:.58rem;
    font-weight:700;
    letter-spacing:.05em;
    text-transform:uppercase;
    border-radius:999px;
    padding:.15rem .42rem;
    background:rgba(56,189,248,.16);
    color:#38bdf8;
    border:1px solid rgba(56,189,248,.35);
}
.tool-upsell-teasers__plan--pro{
    background:rgba(245,158,11,.16);
    color:#f59e0b;
    border-color:rgba(245,158,11,.35);
}
.tool-upsell-teasers__title{font-size:.8rem;font-weight:700;color:var(--text-primary)}
.tool-upsell-teasers__copy{font-size:.72rem;color:var(--text-muted);line-height:1.4}
.sticky-upgrade-cta{
    position:fixed;
    right:1rem;
    bottom:1rem;
    z-index:1030;
    border-radius:999px;
    padding:.58rem 1rem;
    background:var(--gradient-accent);
    color:#fff;
    font-weight:700;
    text-decoration:none;
    box-shadow:0 12px 28px rgba(2,132,199,.35);
}
.sticky-upgrade-cta:hover{filter:brightness(1.05);color:#fff}
@media (max-width: 991px){
    .tool-upsell-teasers__grid{grid-template-columns:1fr}
    .sticky-upgrade-cta{right:.75rem;bottom:.75rem}
    .onboarding-steps__grid{grid-template-columns:1fr}
}

/* TABLE */
.table{color:var(--text-primary)}
.table th{color:var(--text-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;border-color:var(--border);font-weight:600}
.table td{border-color:var(--border);font-size:.875rem;vertical-align:middle}
.table-hover tbody tr:hover td{background:rgba(255,255,255,.02)}

/* FOOTER */
.footer{border-top:1px solid var(--border);padding:3.5rem 0 2rem;margin-top:5rem;color:var(--text-muted);font-size:.85rem}
.footer a{color:var(--text-secondary);text-decoration:none;transition:color .2s}
.footer a:hover{color:var(--accent-light)}

/* ALERTS */
.alert{border:none;border-radius:var(--radius);font-size:.9rem}

/* TOASTS */
.toast-container{position:fixed;top:80px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:380px;pointer-events:none}
.toast-msg{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:14px;background:rgba(22,22,31,.95);border:1px solid var(--border);box-shadow:0 8px 40px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04);backdrop-filter:blur(16px);animation:toastIn .35s cubic-bezier(.34,1.56,.64,1) forwards;min-width:280px;pointer-events:all}
.toast-msg.toast-exit{animation:toastOut .25s ease forwards}
.toast-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem}
.toast-error .toast-icon{background:rgba(240,96,96,.15);color:var(--red)}
.toast-success .toast-icon{background:rgba(0,210,160,.15);color:var(--green)}
.toast-warning .toast-icon{background:rgba(240,160,64,.15);color:var(--orange)}
.toast-info .toast-icon{background:rgba(139,130,224,.12);color:var(--accent-light)}
.toast-body{flex:1;min-width:0}
.toast-title{font-weight:700;font-size:.84rem;color:var(--text-primary);margin-bottom:2px}
.toast-text{font-size:.78rem;color:var(--text-secondary);line-height:1.45}
.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;font-size:1rem;line-height:1;flex-shrink:0;transition:color .2s}
.toast-close:hover{color:var(--text-primary)}
.toast-progress{height:3px;border-radius:0 0 14px 14px;margin:10px -16px -14px;overflow:hidden}
.toast-progress-bar{height:100%;border-radius:3px;animation:toastProgress 4s linear forwards}
.toast-error .toast-progress-bar{background:var(--red)}
.toast-success .toast-progress-bar{background:var(--green)}
.toast-warning .toast-progress-bar{background:var(--orange)}
.toast-info .toast-progress-bar{background:var(--accent)}
@keyframes toastIn{from{opacity:0;transform:translateX(50px) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(50px)}}
@keyframes toastProgress{from{width:100%}to{width:0%}}

/* FAQ */
.accordion-item{border-radius:var(--radius)!important;overflow:hidden;margin-bottom:.5rem;background:var(--bg-card);border:1px solid var(--border)!important;transition:border-color .2s}
.accordion-item:hover{border-color:var(--border-light)!important}
.accordion-button{background:transparent!important;color:var(--text-primary)!important;font-weight:600;font-size:.95rem;box-shadow:none!important;padding:1.1rem 1.4rem}
.accordion-button::after{filter:invert(.5) sepia(0) saturate(0)}
.accordion-button:not(.collapsed){color:var(--accent-light)!important}
.accordion-button:not(.collapsed)::after{filter:invert(.5) sepia(1) saturate(3) hue-rotate(220deg)}
.accordion-body{color:var(--text-secondary);font-size:.9rem;line-height:1.7;padding:0 1.4rem 1.2rem}

/* DIFF */
.diff-removed{background:rgba(240,96,96,.18);color:var(--red);text-decoration:line-through;padding:1px 3px;border-radius:3px}
.diff-added{background:rgba(0,210,160,.14);color:var(--green);padding:1px 3px;border-radius:3px;font-weight:500}

/* STATS COUNTER */
.stats-counter{display:flex;justify-content:center;gap:clamp(2rem,6vw,4.5rem);padding:2.75rem 2rem;border-radius:var(--radius-xl);background:linear-gradient(145deg,rgba(155,147,232,.07),rgba(61,212,176,.04));border:1px solid rgba(184,172,238,.12);box-shadow:0 12px 40px rgba(8,4,24,.2)}
.counter-item{text-align:center;padding:.35rem .5rem}
.counter-value{font-size:clamp(2.5rem,5vw,3.1rem);font-weight:600;letter-spacing:-.02em;background:var(--gradient-hero);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.55rem;font-family:var(--font-elegant)}
.counter-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-weight:600}

/* STEP NUMBERS */
.step-number{width:52px;height:52px;border-radius:50%;background:var(--gradient-accent);color:#fff;font-size:1.15rem;font-weight:700;font-family:var(--font-display);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;box-shadow:0 1px 0 rgba(255,255,255,.12) inset,0 8px 28px var(--accent-glow);flex-shrink:0}

/* BEFORE/AFTER */
.compare-card{border-radius:var(--radius-lg);padding:1.75rem;height:100%}
.compare-card.before{background:rgba(240,96,96,.06);border:1px solid rgba(240,96,96,.25)}
.compare-card.after{background:rgba(0,210,160,.06);border:1px solid rgba(0,210,160,.25)}
.ai-score-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .9rem;border-radius:50px;font-size:.8rem;font-weight:700}
.ai-score-badge.high{background:rgba(240,96,96,.15);color:var(--red);border:1px solid rgba(240,96,96,.3)}
.ai-score-badge.low{background:rgba(0,210,160,.12);color:var(--green);border:1px solid rgba(0,210,160,.3)}

/* TESTIMONIALS */
.testimonial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;height:100%;transition:all .3s;position:relative}
.testimonial-card::before{content:'\201C';position:absolute;top:1rem;right:1.5rem;font-size:4rem;line-height:1;color:var(--border-light);font-family:Georgia,serif}
.testimonial-card:hover{border-color:rgba(139,130,224,.18);transform:translateY(-2px);box-shadow:var(--shadow)}
.testimonial-stars{display:flex;gap:3px;margin-bottom:1rem}
.testimonial-stars i{color:var(--gold);font-size:.85rem}
.testimonial-text{color:var(--text-secondary);font-size:.9rem;line-height:1.75;margin-bottom:1.25rem;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:.75rem}
.testimonial-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}
.testimonial-name{font-weight:700;font-size:.875rem;color:var(--text-primary)}
.testimonial-role{font-size:.78rem;color:var(--text-muted)}

/* CTA SECTION */
.cta-section{background:linear-gradient(155deg,rgba(155,147,232,.12) 0%,rgba(200,170,220,.07) 38%,rgba(232,200,210,.06) 100%);border:1px solid rgba(184,172,238,.22);border-radius:var(--radius-xl);padding:clamp(3.25rem,8vw,4.5rem) 2rem;text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow-card)}
.cta-section::before{content:'';position:absolute;top:-55%;left:50%;transform:translateX(-50%);width:580px;height:400px;background:radial-gradient(ellipse,rgba(196,185,244,.14) 0%,transparent 72%);pointer-events:none}
.cta-section>*{position:relative;z-index:1}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.animate-in{animation:fadeUp .5s ease both}
.animate-in-delay-1{animation:fadeUp .5s .1s ease both}
.animate-in-delay-2{animation:fadeUp .5s .2s ease both}
.animate-in-delay-3{animation:fadeUp .5s .3s ease both}
.reveal-on-scroll{
    opacity:0;
    transform:translateY(14px);
    transition:opacity .45s ease,transform .45s ease;
    will-change:opacity,transform;
}
.reveal-on-scroll.is-visible{
    opacity:1;
    transform:translateY(0);
}

/* MISC */
kbd{background:var(--bg-card)!important;border:1px solid var(--border)!important;color:var(--text-muted)!important;padding:2px 6px;border-radius:4px;font-size:.7rem;font-family:var(--font)}
.score-circle-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:800;font-size:.75rem}

/* RESPONSIVE */
@media(max-width:991px){.section-title{font-size:1.9rem}}
@media(max-width:768px){
    .hero{padding:5rem 0 3.5rem}
    .hero h1{font-size:2.1rem}
    .hero p{font-size:1rem}
    .controls-bar{flex-direction:column;align-items:stretch}
    .mode-pills{flex-wrap:wrap}
    .stats-bar{flex-wrap:wrap;gap:1rem}
    .pricing-price{font-size:2.5rem}
    .stats-counter{gap:1.5rem;flex-wrap:wrap}
    .section-title{font-size:1.7rem}
}
@media(max-width:480px){
    .hero h1{font-size:1.8rem}
    .auth-card{padding:1.75rem;margin:1.5rem auto}
}

/* ============================================
   LIGHT MODE — clean white, readable type (GabrielSoft-inspired)
   Default theme: professional, minimal, sky accent on white
   ============================================ */
body.light-mode{
    --bg-primary:#ffffff;
    --bg-secondary:#f8fafc;
    --bg-card:#ffffff;
    --bg-card-hover:#f1f5f9;
    --bg-input:#f8fafc;
    --accent:#0284c7;
    --accent-light:#0ea5e9;
    --accent-dark:#0369a1;
    --accent-glow:rgba(2,132,199,.14);
    --champagne:#64748b;
    --green:#059669;
    --green-glow:rgba(5,150,105,.12);
    --gold:#b45309;
    --orange:#ea580c;
    --red:#dc2626;
    --blue:#2563eb;
    --violet:#7c3aed;
    --teal:#0d9488;
    --pink:#db2777;
    --text-primary:#0f172a;
    --text-secondary:#475569;
    --text-muted:#64748b;
    --border:#e2e8f0;
    --border-light:#cbd5e1;
    --gradient-accent:linear-gradient(180deg,#0284c7 0%,#0369a1 100%);
    --gradient-hero:linear-gradient(120deg,#0ea5e9 0%,#0284c7 55%,#0369a1 100%);
    --gradient-green:linear-gradient(145deg,#10b981 0%,#059669 100%);
    --gradient-gold:linear-gradient(145deg,#d97706 0%,#b45309 100%);
    --shadow:0 1px 3px rgba(15,23,42,.06);
    --shadow-lg:0 4px 24px rgba(15,23,42,.07);
    --shadow-card:0 1px 2px rgba(15,23,42,.04),0 4px 14px rgba(15,23,42,.04);
    background-color:#ffffff;
    color:#0f172a;
    background-image:none;
}
body.light-mode .hero h1,
body.light-mode .section-title,
body.light-mode .page-title,
body.light-mode .cta-section .section-title,
body.light-mode .auth-card h2{font-family:var(--font-display);letter-spacing:-.025em}
body.light-mode .gradient-text{background:none;-webkit-text-fill-color:var(--text-primary);color:var(--text-primary)}
body.light-mode .counter-value{background:linear-gradient(120deg,#0369a1 0%,#0284c7 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
body.light-mode .navbar{background:rgba(255,255,255,.92)!important;border-bottom:1px solid var(--border);box-shadow:0 1px 0 rgba(255,255,255,.8),0 4px 20px rgba(15,23,42,.04)}
body.light-mode .navbar-brand .brand-icon{background:linear-gradient(145deg,#0ea5e9,#0284c7);box-shadow:0 2px 10px rgba(2,132,199,.2)}
body.light-mode .navbar-brand{color:var(--text-primary)!important}
body.light-mode .navbar-brand .brand-wordmark{color:var(--text-primary)!important}
body.light-mode .navbar-brand .brand-wordmark > span{color:var(--accent)!important}
body.light-mode .section-label{color:#64748b;letter-spacing:.12em}
body.light-mode .stats-counter{background:#f8fafc;border:1px solid var(--border);box-shadow:none}
body.light-mode .trust-marquee-section{background:#f4f4f7;border:1px solid #e8e8ed}
body.light-mode .trust-marquee__item{color:#333}
body.light-mode main.page-home .editor-panel{border-color:var(--border)}
body.light-mode .navbar .nav-link{color:#475569!important}
body.light-mode .navbar .nav-link:hover{color:var(--text-primary)!important;background:#f1f5f9}
body.light-mode .navbar .nav-link.active{color:var(--accent)!important}
body.light-mode .dropdown-menu{background:var(--bg-card);border-color:var(--border);box-shadow:var(--shadow-lg)}
body.light-mode .dropdown-item{color:var(--text-secondary)}
body.light-mode .dropdown-item:hover{background:rgba(2,132,199,.08);color:var(--text-primary)}
body.light-mode .card,body.light-mode .feature-card,body.light-mode .tool-card,body.light-mode .pricing-card,body.light-mode .testimonial-card,body.light-mode .dash-card,body.light-mode .editor-panel,body.light-mode .controls-bar{background:var(--bg-card);border-color:var(--border);color:var(--text-primary)}
body.light-mode .feature-card:hover,body.light-mode .tool-card:hover,body.light-mode .pricing-card:hover{border-color:#bae6fd;box-shadow:var(--shadow-lg)}
body.light-mode .editor-textarea{color:var(--text-primary);background:transparent}
body.light-mode .editor-textarea::placeholder{color:#94a3b8}
body.light-mode .editor-header,body.light-mode .editor-footer{border-color:var(--border);background:#fafafa}
body.light-mode .mode-pill{border-color:var(--border);color:var(--text-secondary);background:var(--bg-input)}
body.light-mode .mode-pill:hover{border-color:var(--accent);color:var(--text-primary);background:#fff}
body.light-mode .mode-pill.active{background:var(--gradient-accent);color:#fff;border-color:transparent}
body.light-mode .level-slider{background:var(--border-light)}
body.light-mode .form-control,body.light-mode .form-select{background:#fff;border-color:var(--border);color:var(--text-primary)}
body.light-mode .form-control:focus,body.light-mode .form-select:focus{background:#fff;border-color:var(--accent);color:var(--text-primary);box-shadow:0 0 0 3px rgba(2,132,199,.12)}
body.light-mode .form-label{color:var(--text-secondary)}
body.light-mode .auth-card{background:#fff;border-color:var(--border);box-shadow:var(--shadow-card)}
body.light-mode .auth-card h2{color:var(--text-primary)}
body.light-mode .btn-outline-light{border-color:var(--border);color:var(--text-primary);background:#fff}
body.light-mode .btn-outline-light:hover{background:#f8fafc;border-color:#94a3b8;color:var(--text-primary)}
body.light-mode .btn-copy{background:#f8fafc;border-color:var(--border);color:var(--text-secondary)}
body.light-mode .btn-copy:hover{border-color:var(--accent);color:var(--accent);background:#fff}
body.light-mode .table{color:var(--text-primary)}
body.light-mode .table th{color:var(--text-muted);border-color:var(--border)}
body.light-mode .table td{border-color:var(--border)}
body.light-mode .hero h1{color:var(--text-primary)}
body.light-mode .hero p{color:var(--text-secondary)}
body.light-mode .hero-badge{background:#f8fafc;border:1px solid var(--border);color:var(--text-secondary);box-shadow:none}
body.light-mode .hero-badge .badge-dot{background:var(--accent);box-shadow:0 0 0 3px rgba(2,132,199,.2)}
body.light-mode .hero::before{background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(2,132,199,.06) 0%,transparent 62%)}
body.light-mode .hero::after{background:linear-gradient(90deg,transparent,var(--border),transparent)}
body.light-mode .hero-note{color:var(--text-muted)}
body.light-mode .footer{background:#f8fafc;border-top:1px solid var(--border);color:var(--text-muted)}
body.light-mode .footer .text-white{color:var(--text-primary)!important}
body.light-mode .footer a{color:var(--text-secondary)}
body.light-mode .footer a:hover{color:var(--accent)}
body.light-mode .footer hr{border-color:var(--border)!important;opacity:1}
body.light-mode .toast-msg{background:rgba(255,255,255,.98);border-color:var(--border);box-shadow:var(--shadow-lg)}
body.light-mode .toast-title{color:var(--text-primary)}
body.light-mode .toast-text{color:var(--text-secondary)}
body.light-mode .accordion-item{background:#fff;border-color:var(--border)!important}
body.light-mode .accordion-button{background:#fff!important;color:var(--text-primary)!important}
body.light-mode .accordion-button::after{filter:none}
body.light-mode .accordion-body{color:var(--text-secondary)}
body.light-mode .diff-removed{background:rgba(220,38,38,.08)}
body.light-mode .diff-added{background:rgba(5,150,105,.08)}
body.light-mode .compare-card.before{background:rgba(220,38,38,.04)}
body.light-mode .compare-card.after{background:rgba(5,150,105,.04)}
body.light-mode .cta-section{background:linear-gradient(165deg,#f0f9ff 0%,#f8fafc 55%);border:1px solid #bae6fd}
body.light-mode .cta-section::before{background:radial-gradient(ellipse,rgba(14,165,233,.08) 0%,transparent 70%)}
body.light-mode .section-divider{background:linear-gradient(90deg,transparent,var(--border),transparent)}
body.light-mode .testimonial-card::before{color:#e2e8f0}
body.light-mode .pricing-card.popular{background:linear-gradient(180deg,#f0f9ff 0%,#ffffff 45%);border-color:#7dd3fc;box-shadow:0 0 0 1px rgba(14,165,233,.15),var(--shadow-card)}
body.light-mode .pricing-card.popular::before{background:var(--gradient-accent)}
body.light-mode .mega-menu-all{background:#f0f9ff;border-color:#bae6fd}
body.light-mode .mega-menu-all:hover{background:#e0f2fe;border-color:#7dd3fc}
body.light-mode .mega-menu-all-icon{background:var(--gradient-accent)}
body.light-mode .mega-menu-link:hover{background:rgba(2,132,199,.07)}
body.light-mode .btn-nav-cta{box-shadow:0 2px 10px rgba(2,132,199,.22)}
body.light-mode .skip-link{background:var(--accent)}

/* Theme toggle */
.theme-toggle{background:none;border:1px solid var(--border);border-radius:50px;padding:.35rem .8rem;cursor:pointer;color:var(--text-secondary);font-size:.8rem;transition:all .2s;display:flex;align-items:center;gap:.4rem;white-space:nowrap}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent-light)}
body.light-mode .theme-toggle{border-color:var(--border);color:var(--text-secondary)}
body.light-mode .theme-toggle:hover{border-color:var(--accent);color:var(--accent)}

/* Header user avatar + menu */
.nav-user-dropdown{position:relative}
.nav-user-toggle{
    display:inline-flex;align-items:center;gap:.35rem;padding:0;border:none;background:transparent;
    color:var(--text-secondary);border-radius:999px;cursor:pointer;transition:color .2s,box-shadow .2s;
}
.nav-user-toggle:hover,.nav-user-toggle:focus-visible{color:var(--accent-light);outline:none}
.nav-user-toggle:focus-visible{box-shadow:0 0 0 2px var(--accent-light)}
.nav-user-avatar{
    width:38px;height:38px;border-radius:50%;
    background:var(--gradient-accent);
    color:#fff;font-size:.78rem;font-weight:700;
    display:inline-flex;align-items:center;justify-content:center;
    box-shadow:0 1px 0 rgba(255,255,255,.12) inset,0 4px 16px var(--accent-glow);
    letter-spacing:.02em;
}
.nav-user-chevron{font-size:.65rem;opacity:.75}
.nav-user-menu{min-width:12.5rem;padding-top:.35rem;padding-bottom:.35rem}
.nav-user-menu .dropdown-item i{opacity:.85}
body.light-mode .nav-user-avatar{
    background:linear-gradient(145deg,#0ea5e9,#0284c7);
    box-shadow:0 2px 10px rgba(2,132,199,.2);
}
body.light-mode .nav-user-toggle{color:#475569}
body.light-mode .nav-user-toggle:hover{color:var(--accent)}

/* Prevent flash — match clean white before CSS loads */
html.light-mode-pending body,body.light-mode{background-color:#ffffff;color:#0f172a}

/* User overrides */
.hero-cta {
    animation: fadeUp .5s .3s ease both;
    gap: 1rem !important;
    margin-bottom: 20px;
}

.hero {
    padding: clamp(4.25rem, 12vw, 4rem) 0 clamp(3.25rem, 8vw, 3.75rem);
    text-align: center;
    position: relative;
    overflow: hidden;
}

.section-title {
    font-size: clamp(2rem, 4.2vw, 1.95rem);
    font-weight: 600;
    letter-spacing: -.03em;
    line-height: 1.1;
    margin-bottom: 1.15rem;
}

/* ── Homepage: JustDone-inspired showcase band + browser extension ── */
.scroll-margin-nav{scroll-margin-top:5.5rem}
.home-showcase-belt{
    margin-left:clamp(.25rem,2vw,.75rem);margin-right:clamp(.25rem,2vw,.75rem);border-radius:var(--radius-xl);
    padding:clamp(2.5rem,6vw,4rem) 0;background:linear-gradient(180deg,rgba(100,116,139,.06) 0%,rgba(148,163,184,.06) 100%);
    border:1px solid var(--border);
}
.showcase-panel{
    background:var(--bg-card);border-radius:28px;border:1px solid var(--border);
    box-shadow:var(--shadow-card);padding:clamp(1.25rem,3.5vw,2rem);height:100%;
}
.showcase-title{
    font-family:var(--font-display);font-weight:700;font-size:clamp(1.35rem,2.4vw,1.85rem);
    letter-spacing:-.03em;line-height:1.2;color:#0c4a6e;margin-bottom:.85rem;
}
.showcase-lead{color:var(--text-secondary);font-size:.975rem;line-height:1.75;margin-bottom:1.25rem}
.showcase-bullets{list-style:none;padding:0;margin:0 0 1.5rem;font-size:.9rem;color:var(--text-secondary)}
.showcase-bullets li{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.55rem;line-height:1.5}
.showcase-bullets i{color:#0d9488;margin-top:.2rem}
.btn-showcase-cta,.btn-showcase-cta-outline{
    display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:.7rem 1.5rem;
    font-weight:600;font-size:.925rem;text-decoration:none;transition:filter .2s,transform .2s,color .2s,background .2s,border-color .2s;
}
.btn-showcase-cta{border:none;color:#fff;background:linear-gradient(180deg,#075985 0%,#0c4a6e 100%);box-shadow:0 2px 14px rgba(8,71,134,.35)}
.btn-showcase-cta:hover{filter:brightness(1.05);transform:translateY(-1px);color:#fff}
.btn-showcase-cta-outline {
    border: 1px solid #a99dec;
    color: #9a90e5;
    background: transparent;
    margin-left: .25rem;
}
.btn-showcase-cta-outline:hover{border-color:#0c4a6e;color:#0c4a6e;background:rgba(14,165,233,.06)}
.showcase-mock{font-size:.8rem;line-height:1.45;color:var(--text-secondary)}
.showcase-mock-split{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:576px){.showcase-mock-split{grid-template-columns:1fr}}
.showcase-mock-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.35rem}
.showcase-mock-input{
    border:1px solid var(--border);border-radius:10px;padding:.55rem .7rem;background:var(--bg-input);
    margin-bottom:.5rem;font-weight:600;color:var(--text-primary);font-size:.78rem;
}
.showcase-mock-upload{display:flex;align-items:center;gap:.4rem;font-size:.72rem;padding:.35rem;border-radius:8px;background:rgba(5,150,105,.06);margin-bottom:.65rem;color:var(--text-secondary)}
.showcase-mock-btn-teal{
    display:inline-block;background:linear-gradient(180deg,#14b8a6 0%,#0d9488 100%);color:#fff!important;
    font-weight:700;font-size:.74rem;padding:.52rem .9rem;border-radius:10px;text-align:center;box-shadow:0 4px 12px rgba(13,148,136,.35);
}
.showcase-mock-quiz{border-left:1px solid var(--border);padding-left:1rem;margin-left:.15rem}
@media(max-width:576px){.showcase-mock-quiz{border-left:none;padding-left:0;margin-left:0;border-top:1px solid var(--border);padding-top:1rem;margin-top:.5rem}}
.showcase-mock-qmeta{font-size:.65rem;color:var(--text-muted);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.06em}
.showcase-mock-qtext{font-size:.82rem;color:var(--text-primary);font-weight:600;margin:0;line-height:1.4}
.showcase-mock-opt{border-radius:8px;padding:.42rem .5rem;margin-bottom:.3rem;background:var(--bg-secondary);font-size:.72rem;color:var(--text-secondary)}
.showcase-mock-opt--correct{background:rgba(5,150,105,.12);border:1px solid rgba(5,150,105,.35);color:var(--green);font-weight:600}
.showcase-mock--detector{padding:.25rem 0 .5rem}
.showcase-detector-toolbar{display:flex;gap:.35rem;margin-bottom:.75rem}
.showcase-chip{
    font-size:.68rem;padding:.35rem .6rem;border-radius:999px;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-muted);
}
.showcase-chip--on{border-color:rgba(2,132,199,.35);background:rgba(2,132,199,.08);color:var(--text-primary)}
.showcase-mock-textarea {
    border: 1px dashed var(--border-light);
    border-radius: 12px;
    min-height: 88px;
    padding: .75rem;
    font-size: .75rem;
    line-height: 1.55;
    color: var(--text-muted);
    /* background: rgba(248, 250, 252, .5); */
}
.showcase-detector-actions{display:flex;gap:.5rem;margin-top:.65rem}
.showcase-ghost-btn{
    flex:1;text-align:center;padding:.42rem;font-size:.72rem;border-radius:10px;border:1px solid var(--border);
    background:var(--bg-input);color:var(--text-secondary);font-weight:500;
}
.showcase-detector-score{
    margin-top:1rem;display:flex;align-items:center;gap:.85rem;padding:.75rem 1rem;border-radius:14px;
    border:1px solid var(--border);background:rgba(239,68,68,.06);flex-wrap:wrap;
}
.showcase-score-ring{font-weight:800;font-size:1.35rem;color:var(--red);min-width:3.25rem;text-align:center}
.showcase-mini-link{margin-left:auto;font-size:.72rem;color:var(--accent);white-space:nowrap}
.extension-panel{
    border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-card);
    box-shadow:var(--shadow-card);padding:clamp(1.75rem,5vw,2.75rem);
}
.extension-points li{display:flex;align-items:center;gap:.65rem;margin-bottom:.6rem;color:var(--text-secondary);font-size:.925rem;line-height:1.45}
.extension-visual-chrome{border-color:var(--border)!important;max-width:320px;background:linear-gradient(180deg,#fafbfc 0%,var(--bg-card) 100%)!important}
.extension-visual-pill{
    border:1px solid var(--border);border-radius:10px;padding:.5rem .65rem;display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:500;color:var(--text-secondary);
    background:#fff;
}
body.light-mode .home-showcase-belt{background:linear-gradient(180deg,#eef2ff 0%,#f8fafc 55%);border-color:#e2e8f0}
body.light-mode .showcase-title{color:#0369a1}
body.light-mode .showcase-chip--on{border-color:#bae6fd;background:#f0f9ff;color:#0369a1}
body.light-mode .showcase-mock-opt--correct{border-color:rgba(5,150,105,.35)}
body.light-mode .extension-panel{background:#fff;border-color:var(--border)}
body.light-mode .btn-showcase-cta{background:linear-gradient(180deg,#0369a1 0%,#0284c7 100%);box-shadow:0 4px 18px rgba(2,132,199,.35)}
body.light-mode .btn-showcase-cta-outline{border-color:#cbd5e1;color:#0369a1}
body.light-mode .btn-showcase-cta-outline:hover{border-color:#0284c7;background:#f0f9ff}
body:not(.light-mode) .showcase-title{color:#bae6fd}
body:not(.light-mode) .showcase-mini-link{color:#7dd3fc}
body:not(.light-mode) .extension-visual-chrome{background:linear-gradient(180deg,rgba(255,255,255,.04),var(--bg-card))!important}
body:not(.light-mode) .extension-visual-pill{background:rgba(255,255,255,.02)}

/* Tool pages — stat pills (JustDone-inspired) */
.tool-subhero-stats{max-width:720px;margin-left:auto;margin-right:auto}
.tool-subhero-stat{
    display:flex;align-items:center;justify-content:center;gap:.5rem;text-align:center;
    font-size:.845rem;color:var(--text-secondary);padding:.6rem .75rem;border-radius:12px;
    border:1px solid var(--border);background:var(--bg-secondary);height:100%;
}
.tool-subhero-stat i{color:var(--accent);font-size:1.05rem}
.tool-subhero-stat strong{color:var(--text-primary);font-weight:600}
.tool-input-mega .editor-textarea{min-height:200px}
.tool-page-wrap + .tool-subhero-stats{margin-top:-.55rem}
.editor-panel .editor-header h6{font-weight:700}
@media (max-width: 767px){
    .tool-page-wrap{margin-bottom:1.6rem}
    .tool-subhero-stats{margin-bottom:1rem!important}
    .tool-subhero-stat{font-size:.8rem;padding:.55rem .65rem}
    .dash-card{padding:1rem}
}
body.light-mode .tool-subhero-stat{background:#f8fafc;border-color:var(--border)}
body.light-mode .tool-subhero-stat i{color:var(--accent)}
.doc-upload-inline{background:rgba(255,255,255,.02)}
.doc-upload-inline .form-control{background:var(--bg-input);border-color:var(--border);color:var(--text-primary)}
.doc-upload-inline .form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(2,132,199,.12)}
.doc-upload-inline .form-text{font-size:.75rem;color:var(--text-muted)}
body.light-mode .doc-upload-inline{background:#f8fafc}

/* Citation generator — long-form landing (JustDone-inspired layout) */
.citation-output-box{background:var(--bg-secondary);font-size:.9rem;line-height:1.8;color:var(--text-primary);word-break:break-word}
.tool-landing-title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.35rem,2.6vw,1.95rem);letter-spacing:-.025em;line-height:1.2;color:var(--text-primary);margin-bottom:0}
.tool-landing-text{color:var(--text-secondary);line-height:1.75;font-size:.95rem}
.tool-landing-step-item{background:var(--bg-card)!important;color:var(--text-secondary)!important;font-size:.9rem;line-height:1.65}
.tool-landing-accordion .accordion-button{font-size:.9rem}
body.light-mode .tool-landing-step-item{background:#fff!important}
body.light-mode .tool-landing-mini{background:#f8fafc!important;border-color:var(--border)!important}

/* Homepage: full-bleed promo above FAQ */
.home-promo-strip{padding-left:clamp(.25rem,2vw,.75rem)!important;padding-right:clamp(.25rem,2vw,.75rem)!important}
.home-promo-strip__inner{
    position:relative;overflow:hidden;border-radius:var(--radius-xl);
    background:linear-gradient(115deg,#0c4a6e 0%,#0369a1 42%,#0ea5e9 96%);
    box-shadow:0 18px 50px rgba(3,105,161,.22);
    padding:clamp(2rem,5vw,3.25rem) 0;
}
.home-promo-strip__glow{
    position:absolute;top:-40%;right:-8%;width:min(420px,55vw);height:min(420px,55vw);
    border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.22) 0%,transparent 68%);pointer-events:none;
}
.home-promo-strip__eyebrow{
    display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
    color:rgba(255,255,255,.78);margin-bottom:.75rem;font-family:var(--font-display);
}
.home-promo-strip__title{
    font-family:var(--font-display);font-weight:700;color:#fff;font-size:clamp(1.45rem,3.8vw,2.35rem);
    line-height:1.15;letter-spacing:-.03em;margin-bottom:1rem;text-wrap:balance;
}
.home-promo-strip__lead{font-size:1.02rem;line-height:1.7;color:rgba(255,255,255,.88);max-width:36rem;margin-left:auto;margin-right:auto}
@media (min-width:992px){
    .home-promo-strip__lead{margin-left:0}
}
.home-promo-strip__note{font-size:.78rem;color:rgba(255,255,255,.65);letter-spacing:.03em}
.btn-promo-strip-solid{
    border:none;font-weight:700;background:#fff;color:#0369a1!important;box-shadow:0 4px 20px rgba(0,0,0,.12);
    transition:transform .2s,filter .2s,box-shadow .2s;
}
.btn-promo-strip-solid:hover{background:#f8fafc;color:#0284c7!important;transform:translateY(-2px);filter:brightness(1.02)}
.btn-promo-strip-ghost{
    border:2px solid rgba(255,255,255,.42);font-weight:700;background:rgba(255,255,255,.08);color:#fff!important;
    backdrop-filter:blur(10px);transition:border-color .2s,background .2s,transform .2s;
}
.btn-promo-strip-ghost:hover{border-color:rgba(255,255,255,.75);background:rgba(255,255,255,.14);color:#fff!important;transform:translateY(-2px)}
body:not(.light-mode) .home-promo-strip__inner{
    background:linear-gradient(120deg,#1e1b36 0%,#312e81 45%,#0369a1 100%);
    box-shadow:0 18px 48px rgba(0,0,0,.35);
}

/* Tools page — slide-in dock (theme-matched; toggle on viewport edge) */
body.tools-dock-open{overflow:hidden;touch-action:none;}
.tools-dock{position:relative;z-index:1025;pointer-events:none;}
.tools-dock.is-open{pointer-events:auto;}
.tools-dock__toggle{
    pointer-events:auto;
    position:fixed;
    left:0;
    top:50%;
    transform:translateY(-50%);
    z-index:1032;
    width:44px;
    min-height:120px;
    padding:.5rem .35rem;
    border:1px solid var(--border);
    border-left:none;
    border-radius:0 14px 14px 0;
    background:var(--bg-card);
    color:var(--accent-light);
    box-shadow:var(--shadow-card);
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    transition:left .32s cubic-bezier(.22,1,.36,1),background .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease;
}
.tools-dock__toggle:hover{
    border-color:rgba(139,130,224,.35);
    color:var(--accent);
    box-shadow:0 8px 28px rgba(8,4,24,.22);
}
body.light-mode .tools-dock__toggle{
    background:#fff;
    border-color:var(--border);
    color:var(--accent);
}
.tools-dock.is-open .tools-dock__toggle{
    left:min(104px,22vw);
    z-index:1042;
    background:var(--bg-card);
    color:var(--accent-light);
    border:1px solid var(--border);
    border-left:1px solid var(--border);
}
.tools-dock__backdrop{
    position:fixed;
    inset:0;
    z-index:1038;
    background:rgba(8,4,20,.42);
    backdrop-filter:blur(2px);
    opacity:0;
    visibility:hidden;
    transition:opacity .28s ease,visibility .28s ease;
    pointer-events:none;
}
.tools-dock.is-open .tools-dock__backdrop{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
}
body.light-mode .tools-dock__backdrop{background:rgba(15,23,42,.25);}
.tools-dock__panel{
    position:fixed;
    top:0;
    left:0;
    bottom:0;
    width:min(104px,22vw);
    max-width:120px;
    z-index:1040;
    display:flex;
    flex-direction:column;
    padding:0;
    margin:0;
    background:var(--bg-card);
    border-right:1px solid var(--border);
    box-shadow:var(--shadow-lg);
    transform:translate3d(-100%,0,0);
    transition:transform .32s cubic-bezier(.22,1,.36,1);
    overflow:hidden;
    -webkit-overflow-scrolling:touch;
}
.tools-dock.is-open .tools-dock__panel{transform:translate3d(0,0,0);}
.tools-dock__panel-head{
    flex-shrink:0;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:.35rem;
    padding:.75rem .55rem;
    border-bottom:1px solid var(--border);
    background:rgba(255,255,255,.02);
}
body.light-mode .tools-dock__panel-head{background:#fafafa;}
.tools-dock__title{
    font-size:.58rem;
    font-weight:700;
    letter-spacing:.1em;
    text-transform:uppercase;
    color:var(--text-muted);
    line-height:1.2;
    max-width:4.5rem;
}
.tools-dock__close{padding:.35rem .45rem!important;min-width:auto;}
.tools-dock__nav{
    flex:1;
    overflow-y:auto;
    overflow-x:hidden;
    padding:.5rem .45rem .85rem;
}
.tools-sidebar__nav{display:flex;flex-direction:column;align-items:stretch;gap:.18rem;}
.tools-sidebar__link{
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:.28rem;padding:.5rem .25rem;
    border-radius:12px;color:var(--text-secondary);font-size:.65rem;font-weight:600;text-align:center;
    line-height:1.15;text-decoration:none;transition:background .15s ease,color .15s ease;
}
.tools-sidebar__link:hover{
    background:rgba(139,130,224,.1);
    color:var(--text-primary);
}
body.light-mode .tools-sidebar__link:hover{background:rgba(2,132,199,.08);color:var(--text-primary);}
.tools-sidebar__link.is-active{
    background:rgba(139,130,224,.15);
    color:var(--accent-light);
    box-shadow:0 0 0 1px rgba(139,130,224,.22);
}
body.light-mode .tools-sidebar__link.is-active{
    background:rgba(2,132,199,.1);
    color:var(--accent);
    box-shadow:0 0 0 1px rgba(2,132,199,.2);
}
.tools-sidebar__icon-wrap{
    width:40px;height:40px;display:flex;align-items:center;justify-content:center;
    border-radius:10px;font-size:1.12rem;color:var(--accent-light);
    background:rgba(139,130,224,.08);
}
body.light-mode .tools-sidebar__icon-wrap{background:rgba(2,132,199,.08);color:var(--accent);}
.tools-sidebar__link--primary .tools-sidebar__icon-wrap{
    background:var(--gradient-accent);
    color:#fff!important;
    box-shadow:0 2px 12px var(--accent-glow);
}
.tools-sidebar__link--primary:hover .tools-sidebar__icon-wrap{filter:brightness(1.05);}
.tools-sidebar__link--primary .tools-sidebar__label{color:var(--text-primary);}
.tools-sidebar__label{display:block;max-width:78px;word-break:break-word;hyphens:auto;}
.tools-sidebar__plan{
    display:inline-block;
    font-size:.52rem;
    font-weight:700;
    letter-spacing:.05em;
    text-transform:uppercase;
    border-radius:999px;
    padding:.15rem .4rem;
    line-height:1;
    border:1px solid transparent;
}
.tools-sidebar__plan--free{background:rgba(100,116,139,.14);color:var(--text-muted);border-color:rgba(100,116,139,.25)}
.tools-sidebar__plan--basic{background:rgba(56,189,248,.16);color:#38bdf8;border-color:rgba(56,189,248,.35)}
.tools-sidebar__plan--pro{background:rgba(245,158,11,.16);color:#f59e0b;border-color:rgba(245,158,11,.35)}
.tools-sidebar__link--soon{
    cursor:default;
    opacity:.72;
    color:var(--text-muted);
}
.tools-sidebar__link--soon .tools-sidebar__icon-wrap{
    opacity:.85;
    background:var(--bg-secondary);
}
.tools-sidebar__soon{
    display:block;
    font-size:.58rem;
    font-weight:700;
    letter-spacing:.06em;
    text-transform:uppercase;
    color:var(--text-muted);
    margin-top:-.1rem;
}
.tools-page-main{min-width:0;}
#tools-grid{scroll-margin-top:6rem;}
@media (prefers-reduced-motion:reduce){
    .tools-dock__panel,.tools-dock__backdrop,.tools-dock__toggle,.tools-sidebar__link{transition:none}
    .reveal-on-scroll{opacity:1!important;transform:none!important}
}
