.presentation-page{
--p:#667eea;--pd:#764ba2;--ok:#10b981;--warn:#f59e0b;--err:#ef4444;--txt:#1f2937;--muted:#6b7280;--bg2:#f9fafb;--border:#e5e7eb;
--grad:linear-gradient(135deg,#667eea,#764ba2);--gs:linear-gradient(135deg,rgba(102,126,234,.07),rgba(118,75,162,.07));
--sh:0 4px 16px rgba(102,126,234,.12),0 2px 6px rgba(0,0,0,.06);--r:16px;--rs:8px;
}
.presentation-page .hero{min-height:90vh;display:flex;align-items:center;background:linear-gradient(160deg,#f0f4ff,#f9f0ff 50%,#f0fdf4);padding:4rem 2rem;position:relative;overflow:hidden}
.presentation-page .hero::before{content:'';position:absolute;width:560px;height:560px;background:radial-gradient(circle,rgba(102,126,234,.12),transparent 70%);top:-120px;right:-80px;border-radius:50%}
.presentation-page .hi{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;position:relative;z-index:1}
.presentation-page .badge{display:inline-flex;align-items:center;gap:6px;background:rgba(102,126,234,.1);color:var(--p);padding:.3rem .8rem;border-radius:100px;font-size:.78rem;font-weight:700;margin-bottom:1.1rem;border:1px solid rgba(102,126,234,.2)}
.presentation-page h1{font-size:clamp(1.9rem,4vw,3rem);font-weight:800;line-height:1.15;margin-bottom:1.1rem;letter-spacing:-.5px}
.presentation-page h1 span{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.presentation-page .hp{font-size:1.05rem;color:var(--muted);line-height:1.75;margin-bottom:1.75rem;max-width:460px}
.presentation-page .hb{display:flex;gap:1rem;flex-wrap:wrap}
.presentation-page .bp{background:var(--grad);color:#fff;border:none;padding:.8rem 1.9rem;border-radius:var(--rs);font-size:.97rem;font-weight:700;cursor:pointer;text-decoration:none;transition:all .2s;box-shadow:0 4px 16px rgba(102,126,234,.4);display:inline-block}.bp:hover{transform:translateY(-2px)}
.presentation-page .bo{background:transparent;color:var(--p);border:2px solid var(--p);padding:.75rem 1.75rem;border-radius:var(--rs);font-size:.97rem;font-weight:700;text-decoration:none;transition:all .2s;display:inline-block}.bo:hover{background:var(--gs);transform:translateY(-2px)}
.presentation-page .hcard{background:#fff;border-radius:22px;padding:1.6rem;box-shadow:0 20px 60px rgba(102,126,234,.18),0 8px 20px rgba(0,0,0,.08);max-width:390px;width:100%;margin:0 auto}
.presentation-page .hch{display:flex;align-items:center;gap:10px;margin-bottom:1.3rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.hch h3{font-size:.95rem;font-weight:700}.hch p{font-size:.77rem;color:var(--muted)}
.presentation-page .hcard-shield-bg{fill:rgba(102,126,234,.1)}.presentation-page .hcard-shield-stop-a{stop-color:#667eea}.presentation-page .hcard-shield-stop-b{stop-color:#764ba2}
.presentation-page .dr{display:flex;align-items:center;gap:9px;padding:.6rem;border-radius:var(--rs);margin-bottom:.38rem;background:var(--bg2)}
.presentation-page .dic{width:32px;height:32px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.presentation-page .ib{background:rgba(102,126,234,.1)}.ig{background:rgba(16,185,129,.1)}.ia{background:rgba(245,158,11,.1)}
.presentation-page .dn{font-size:.83rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dm{font-size:.73rem;color:var(--muted)}
.presentation-page .tag{font-size:.69rem;font-weight:700;padding:.15rem .5rem;border-radius:100px;flex-shrink:0}
.presentation-page .te{background:rgba(102,126,234,.1);color:var(--p)}.tg{background:rgba(16,185,129,.1);color:var(--ok)}.ta{background:rgba(245,158,11,.1);color:var(--warn)}
.presentation-page .hcf{margin-top:1.1rem;padding-top:1rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.presentation-page .hcf p{font-size:.78rem;color:var(--muted)}.live{display:flex;align-items:center;gap:5px;font-size:.78rem;font-weight:700;color:var(--ok)}
.presentation-page section{padding:5rem 2rem}.si{max-width:1200px;margin:0 auto}
.presentation-page .lbl{display:inline-block;background:var(--gs);color:var(--p);padding:.25rem .8rem;border-radius:100px;font-size:.77rem;font-weight:700;letter-spacing:.4px;text-transform:uppercase;margin-bottom:.65rem;border:1px solid rgba(102,126,234,.15)}
.presentation-page .ttl{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;line-height:1.2;letter-spacing:-.3px;margin-bottom:.65rem}
.presentation-page .sub{font-size:.97rem;color:var(--muted);line-height:1.7;max-width:540px}
.presentation-page .tc{text-align:center}.tc .sub{margin:0 auto}
.presentation-page .altbg{background:var(--bg2)}
.presentation-page .g2{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;margin-top:2.5rem;align-items:start}
.presentation-page .plist{list-style:none}.plist li{display:flex;gap:11px;align-items:flex-start;padding:.85rem 0;border-bottom:1px solid var(--border)}.plist li:last-child{border-bottom:none}
.presentation-page .pic{width:32px;height:32px;border-radius:var(--rs);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.presentation-page .pe{background:rgba(239,68,68,.1)}.pk{background:rgba(16,185,129,.1)}
.presentation-page .plist h4{font-size:.91rem;font-weight:700;margin-bottom:.18rem}.plist p{font-size:.85rem;color:var(--muted);line-height:1.5}
.presentation-page .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2.5rem}
.presentation-page .step{background:#fff;border-radius:var(--r);padding:1.5rem 1rem;text-align:center;border:1px solid var(--border);transition:transform .2s,box-shadow .2s}.step:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.presentation-page .snum{width:44px;height:44px;border-radius:50%;background:var(--grad);color:#fff;font-size:1rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 4px 12px rgba(102,126,234,.35)}
.presentation-page .step h4{font-size:.93rem;font-weight:700;margin-bottom:.4rem}.step p{font-size:.83rem;color:var(--muted);line-height:1.55}
.presentation-page .ftabs{display:flex;gap:.45rem;flex-wrap:wrap;margin:2rem 0 1.6rem}
.presentation-page .tb{display:flex;align-items:center;gap:6px;padding:.55rem 1.1rem;border-radius:var(--rs);border:2px solid var(--border);background:transparent;color:var(--muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}
.presentation-page .tb:hover{border-color:var(--p);color:var(--p);background:var(--gs)}.tb.on{border-color:var(--p);background:var(--grad);color:#fff}
.presentation-page .tp{display:none;animation:presentation-fi .3s ease}.tp.on{display:grid;grid-template-columns:1fr 1fr;gap:2.75rem;align-items:center}
@keyframes presentation-fi{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.presentation-page .tc3 h3{font-size:1.35rem;font-weight:800;margin-bottom:.65rem}.tc3 p{color:var(--muted);line-height:1.7;margin-bottom:1.1rem;font-size:.95rem}
.presentation-page .fl{list-style:none}.fl li{display:flex;align-items:flex-start;gap:8px;margin-bottom:.55rem;font-size:.9rem;line-height:1.45}
.presentation-page .fl li::before{content:'';width:16px;height:16px;border-radius:50%;background:var(--grad);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 18'%3E%3Cpath d='M5 9l3 3 5-5' stroke='white' stroke-width='2' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");background-size:contain;flex-shrink:0;margin-top:2px}
.presentation-page .tvis{background:var(--gs);border-radius:16px;padding:1.6rem;border:1px solid rgba(102,126,234,.12)}
.presentation-page .win{background:#fff;border-radius:10px;box-shadow:var(--sh);overflow:hidden}
.presentation-page .wbar{padding:.5rem .85rem;background:#f3f4f6;display:flex;gap:5px;align-items:center}
.presentation-page .dot{width:9px;height:9px;border-radius:50%}.dr2{background:#ef4444}.dy{background:#f59e0b}.dg{background:#10b981}
.presentation-page .wb{padding:1.1rem}
.presentation-page .secgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.5rem}
.presentation-page .sc{display:flex;flex-direction:column;align-items:center;text-align:center;background:#fff;border-radius:var(--r);padding:1.5rem;border:1px solid var(--border);transition:all .2s}.sc:hover{transform:translateY(-3px);box-shadow:var(--sh);border-color:rgba(102,126,234,.3)}
.presentation-page .sic{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto .85rem;flex-shrink:0}
.presentation-page .sc h4{font-size:.94rem;font-weight:700;margin-bottom:.38rem;width:100%}.sc p{font-size:.84rem;color:var(--muted);line-height:1.6;width:100%}
.presentation-page .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;margin-top:2.5rem}
.presentation-page .stat{text-align:center;padding:1.65rem 1rem;border-radius:var(--r);border:1px solid var(--border);background:var(--gs)}
.presentation-page .sn{font-size:2.2rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.3rem}
.presentation-page .sl{font-size:.86rem;color:var(--muted);font-weight:500}
.presentation-page .plans{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:2.5rem}
.presentation-page .plan{border-radius:var(--r);padding:1.75rem;border:2px solid var(--border);background:#fff;transition:all .25s;position:relative;overflow:hidden}
.presentation-page .plan:hover{border-color:var(--p);box-shadow:var(--sh);transform:translateY(-4px)}
.presentation-page .plan.feat{border-color:var(--p);background:linear-gradient(160deg,#fafbff,#f5f0ff);box-shadow:var(--sh)}
.presentation-page .pbadge{position:absolute;top:1.1rem;right:1.1rem;background:var(--grad);color:#fff;font-size:.67rem;font-weight:700;padding:.2rem .55rem;border-radius:100px}
.presentation-page .pn{font-size:1rem;font-weight:700;margin-bottom:.4rem}
.presentation-page .pp{font-size:2.2rem;font-weight:800;line-height:1;margin-bottom:.18rem;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.presentation-page .pp span{font-size:.88rem;font-weight:500;color:var(--muted);-webkit-text-fill-color:var(--muted)}
.presentation-page .pd{font-size:.83rem;color:var(--muted);margin-bottom:1.3rem;padding-bottom:1.3rem;border-bottom:1px solid var(--border)}
.presentation-page .pfl{list-style:none}.pfl li{display:flex;align-items:center;gap:7px;font-size:.86rem;padding:.32rem 0}
.presentation-page .pcta{width:100%;margin-top:1.5rem;padding:.78rem;border-radius:var(--rs);font-size:.92rem;font-weight:700;cursor:pointer;text-align:center;display:block;text-decoration:none;transition:all .2s}
.presentation-page .pcp{background:var(--grad);color:#fff;border:none;box-shadow:0 4px 14px rgba(102,126,234,.35)}.pcp:hover{transform:translateY(-2px)}
.presentation-page .pco{background:transparent;color:var(--p);border:2px solid var(--p)}.pco:hover{background:var(--gs);transform:translateY(-2px)}
.presentation-page .faqlist{margin-top:2rem;max-width:720px}
.presentation-page .faqitem{border-bottom:1px solid var(--border)}
.presentation-page .faqq{width:100%;text-align:left;padding:1.1rem 0;background:none;border:none;font-size:.95rem;font-weight:600;color:var(--txt);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:color .2s}.faqq:hover{color:var(--p)}
.presentation-page .chev{width:18px;height:18px;transition:transform .25s;color:var(--muted);flex-shrink:0}
.presentation-page .faqitem.op .chev{transform:rotate(180deg);color:var(--p)}
.presentation-page .faqa{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s;font-size:.89rem;color:var(--muted);line-height:1.7}
.presentation-page .faqitem.op .faqa{max-height:none;padding-bottom:1.1rem}
.presentation-page .ctabg{background:var(--grad);padding:4.5rem 2rem;text-align:center;position:relative;overflow:hidden}
.presentation-page .ctabg::before{content:'';position:absolute;width:440px;height:440px;background:rgba(255,255,255,.05);border-radius:50%;top:-180px;right:-70px}
.presentation-page .ctabg h2{color:#fff;font-size:clamp(1.65rem,3.5vw,2.5rem);font-weight:800;margin-bottom:.9rem;position:relative;z-index:1}
.presentation-page .ctabg p{color:rgba(255,255,255,.82);font-size:1.03rem;max-width:490px;margin:0 auto 1.75rem;position:relative;z-index:1}
.presentation-page .bw{background:#fff;color:var(--p);padding:.85rem 2.1rem;border-radius:var(--rs);font-size:.97rem;font-weight:700;border:none;cursor:pointer;text-decoration:none;display:inline-block;position:relative;z-index:1;transition:all .2s;box-shadow:0 4px 18px rgba(0,0,0,.14)}.bw:hover{transform:translateY(-2px)}
@media(max-width:900px){.presentation-page .hi,.presentation-page .g2,.presentation-page .tp.on,.presentation-page .steps,.presentation-page .secgrid,.presentation-page .stats,.presentation-page .plans{grid-template-columns:1fr}}

html:has(.presentation-page){scroll-behavior:smooth}
.presentation-page section[id]{scroll-margin-top:5.5rem}
#top{scroll-margin-top:0}
[data-bs-theme="dark"] .presentation-page{--txt:var(--bs-body-color);--muted:var(--bs-secondary-color);--bg2:var(--bs-tertiary-bg);--border:var(--bs-border-color)}
.presentation-nav{
--p:#667eea;--pd:#764ba2;--muted:#6b7280;--border:#e5e7eb;
--grad:linear-gradient(135deg,#667eea,#764ba2);--rs:8px;
position:sticky;top:0;z-index:1030;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);box-shadow:0 1px 8px rgba(102,126,234,.08)
}
.presentation-nav-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"logo links actions";align-items:center;padding:.75rem 2rem;gap:1.5rem}
.presentation-nav-logo{grid-area:logo;font-size:1.15rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent;text-decoration:none;flex-shrink:0}
.presentation-nav-links{grid-area:links;display:flex;list-style:none;margin:0;padding:0;gap:1.25rem;justify-content:center;justify-self:center;min-width:0;width:100%}
.presentation-nav-links a{color:var(--muted);font-size:.9rem;font-weight:600;text-decoration:none;white-space:nowrap;transition:color .2s}
.presentation-nav-links a:hover{color:var(--p)}
.presentation-nav-login{color:var(--muted);font-size:.9rem;font-weight:600;text-decoration:none;white-space:nowrap;padding:.55rem .25rem;transition:color .2s}
.presentation-nav-login:hover{color:var(--p)}
.presentation-nav-cta{background:var(--grad);color:#fff!important;-webkit-text-fill-color:#fff;padding:.55rem 1.25rem;border-radius:var(--rs);font-size:.88rem;font-weight:700;text-decoration:none;box-shadow:0 4px 12px rgba(102,126,234,.35);flex-shrink:0;transition:transform .2s,box-shadow .2s;border:none}
.presentation-nav-cta:hover,.presentation-nav-cta:focus{color:#fff!important;-webkit-text-fill-color:#fff;transform:translateY(-1px);box-shadow:0 6px 16px rgba(102,126,234,.45)}
.presentation-nav-actions{grid-area:actions;display:flex;align-items:center;gap:.75rem;flex-shrink:0;justify-self:end}
.presentation-nav-theme{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;padding:0;border:1px solid var(--border);border-radius:var(--rs);background:transparent;color:var(--muted);cursor:pointer;transition:border-color .2s,color .2s;flex-shrink:0}
.presentation-nav-theme:hover{border-color:var(--p);color:var(--p)}
.presentation-nav-links li{flex-shrink:0}
.presentation-nav-links::-webkit-scrollbar{height:3px}
.presentation-nav-links::-webkit-scrollbar-thumb{background:rgba(102,126,234,.35);border-radius:3px}
@media(max-width:900px){
.presentation-nav-inner{grid-template-columns:1fr auto;grid-template-areas:"logo actions" "links links";padding:.65rem 1rem;gap:.55rem}
.presentation-nav-logo{min-width:0;flex-shrink:0}
.presentation-nav-actions{justify-self:end;flex-shrink:0;gap:.5rem}
.presentation-nav-links{justify-self:stretch;width:100%;max-width:100%;justify-content:flex-start;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;gap:.85rem;padding:.15rem 0 .25rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.presentation-page section[id]{scroll-margin-top:6.75rem}
}
@media(max-width:767.98px){
.presentation-nav-inner{padding:.6rem .85rem;gap:.5rem}
.presentation-nav-actions{gap:.45rem}
.presentation-nav-links{gap:.75rem}
.presentation-nav-links a{font-size:.85rem}
}
[data-bs-theme="dark"] .presentation-nav{
--p:#8ba4f8;--pd:#a87fd4;--muted:var(--bs-secondary-color);--border:var(--bs-border-color);
--grad:linear-gradient(135deg,#8ba4f8,#a87fd4);
background:rgba(33,37,41,.92);border-bottom-color:var(--bs-border-color);box-shadow:0 1px 8px rgba(0,0,0,.25)
}
[data-bs-theme="dark"] .presentation-nav-logo{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent}
[data-bs-theme="dark"] .presentation-nav-login{color:var(--bs-secondary-color)}
[data-bs-theme="dark"] .presentation-nav-login:hover{color:var(--p)}
[data-bs-theme="dark"] .presentation-nav-cta{box-shadow:0 4px 14px rgba(139,164,248,.35)}
[data-bs-theme="dark"] .presentation-nav-cta:hover{box-shadow:0 6px 18px rgba(139,164,248,.45)}
[data-bs-theme="dark"] .presentation-nav-theme{border-color:var(--bs-border-color);color:var(--bs-secondary-color)}
[data-bs-theme="dark"] .presentation-nav-theme:hover{border-color:var(--p);color:var(--p)}
[data-bs-theme="dark"] .presentation-page .hcard,[data-bs-theme="dark"] .presentation-page .step,[data-bs-theme="dark"] .presentation-page .sc,[data-bs-theme="dark"] .presentation-page .plan,[data-bs-theme="dark"] .presentation-page .win{background:var(--bs-body-bg)}
[data-bs-theme="dark"] .presentation-page .hcard-shield-bg{fill:rgba(139,164,248,.15)}[data-bs-theme="dark"] .presentation-page .hcard-shield-stop-a{stop-color:#8ba4f8}[data-bs-theme="dark"] .presentation-page .hcard-shield-stop-b{stop-color:#a87fd4}
[data-bs-theme="dark"] .presentation-page .hero{background:linear-gradient(160deg,rgba(102,126,234,.15),rgba(118,75,162,.1) 50%,rgba(16,185,129,.06))}
[data-bs-theme="dark"] .presentation-page .plan.feat{background:linear-gradient(160deg,rgba(102,126,234,.15),rgba(118,75,162,.12))}

/* ── Auth & Pricing pages — shared design tokens ── */
.auth-page,.pricing-page{
--p:#667eea;--pd:#764ba2;--ok:#10b981;--warn:#f59e0b;--err:#ef4444;--txt:#1f2937;--muted:#6b7280;--bg2:#f9fafb;--border:#e5e7eb;
--grad:linear-gradient(135deg,#667eea,#764ba2);--gs:linear-gradient(135deg,rgba(102,126,234,.07),rgba(118,75,162,.07));
--sh:0 4px 16px rgba(102,126,234,.12),0 2px 6px rgba(0,0,0,.06);--r:16px;--rs:8px;
}

/* ── Auth page ── */
.auth-page .auth-wrap{min-height:calc(100vh - 70px);display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#f0f4ff,#f9f0ff 50%,#f0fdf4);border-radius:24px;padding:2.5rem 1rem;position:relative;overflow:hidden;margin:1rem 0}
.auth-page .auth-wrap::before{content:'';position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(102,126,234,.12),transparent 70%);top:-150px;right:-100px;border-radius:50%;pointer-events:none}
.auth-page .auth-wrap::after{content:'';position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(16,185,129,.08),transparent 70%);bottom:-130px;left:-90px;border-radius:50%;pointer-events:none}
.auth-page .auth-card{background:var(--bs-body-bg,#fff);border-radius:22px;box-shadow:0 20px 60px rgba(102,126,234,.18),0 8px 20px rgba(0,0,0,.08);overflow:hidden;position:relative;z-index:1;border:none}
.auth-page .auth-accent-bar{height:4px;background:var(--grad);border-radius:4px 4px 0 0}
.auth-page .ttl-grad{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.auth-page .auth-link{color:var(--p);text-decoration:none;font-weight:600}
.auth-page .auth-link:hover{color:var(--pd)}
.auth-page .auth-divider{display:flex;align-items:center;gap:.75rem;color:var(--muted);font-size:.78rem;margin:1.25rem 0}
.auth-page .auth-divider::before,.auth-page .auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-page .resend-summary{list-style:none;cursor:pointer;text-align:center;font-size:.8rem;color:var(--muted);padding:.4rem 0;transition:color .2s}
.auth-page .resend-summary:hover{color:var(--p)}
.auth-page .auth-trust{display:flex;align-items:center;justify-content:center;gap:1.25rem;flex-wrap:wrap}
.auth-page .auth-trust small{display:flex;align-items:center;gap:5px}
.auth-page .step-section-label{display:inline-flex;align-items:center;gap:6px;background:var(--gs);border-left:3px solid var(--p);border-radius:0 var(--rs) var(--rs) 0;padding:.45rem .9rem;margin-bottom:1rem;font-size:.88rem;font-weight:600;color:var(--p)}
.auth-page .password-reqs{display:grid;grid-template-columns:1fr 1fr;gap:.25rem .75rem;margin-top:.55rem}
.auth-page .req-item{font-size:.75rem;color:var(--muted);display:flex;align-items:center;gap:5px;transition:color .2s}
.auth-page .req-item::before{content:'○';font-size:.65rem;color:var(--border);transition:color .2s}
.auth-page .req-item.met{color:#059669}
.auth-page .req-item.met::before{content:'✓';color:var(--ok)}
@media(max-width:575.98px){
.auth-page .auth-wrap{padding:1.25rem .5rem;border-radius:0;margin:0;min-height:auto}
.auth-page .password-reqs{grid-template-columns:1fr}
.auth-page .auth-trust{gap:.75rem}
}

/* ── Pricing page ── */
.pricing-page .page-hero{background:linear-gradient(160deg,#f0f4ff,#f9f0ff 50%,#f0fdf4);border-radius:24px;padding:3.5rem;margin-bottom:2.5rem;position:relative;overflow:hidden}
.pricing-page .page-hero::before{content:'';position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(102,126,234,.12),transparent 70%);top:-150px;right:-100px;border-radius:50%;pointer-events:none}
.pricing-page .page-hero::after{content:'';position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(16,185,129,.08),transparent 70%);bottom:-150px;left:-100px;border-radius:50%;pointer-events:none}
.pricing-page .lbl{display:inline-block;background:var(--gs);color:var(--p);padding:.25rem .8rem;border-radius:100px;font-size:.77rem;font-weight:700;letter-spacing:.4px;text-transform:uppercase;margin-bottom:.65rem;border:1px solid rgba(102,126,234,.15)}
.pricing-page .ttl{font-size:clamp(1.4rem,3vw,2rem);font-weight:800;line-height:1.2;letter-spacing:-.3px;margin-bottom:.5rem}
.pricing-page .ttl-grad{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pricing-page .hero-sub{color:var(--muted);max-width:480px;margin:0 auto 1rem;font-size:1.02rem;line-height:1.75}
.pricing-page .status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:12px;font-size:.88rem}
.pricing-page .status-badge.ok{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:#065f46}
.pricing-page .status-badge.warn{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);color:#92400e}
.pricing-page .billing-toggle{display:inline-flex;background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:5px;gap:4px}
.pricing-page .billing-toggle input[type="radio"]{display:none}
.pricing-page .billing-toggle label{padding:.5rem 1.3rem;border-radius:10px;font-size:.88rem;font-weight:600;color:var(--muted);cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:7px;margin:0}
.pricing-page .billing-toggle input[type="radio"]:checked+label{background:var(--grad);color:#fff;box-shadow:0 3px 10px rgba(102,126,234,.4)}
.pricing-page .save-badge{background:rgba(16,185,129,.15);color:#059669;font-size:.68rem;padding:.1rem .4rem;border-radius:100px;font-weight:700;transition:all .25s}
.pricing-page .billing-toggle input[type="radio"]:checked+label .save-badge{background:rgba(255,255,255,.25);color:#fff}
.pricing-page .plan{border-radius:var(--r);padding:1.75rem;border:2px solid var(--border);background:#fff;transition:all .25s;position:relative;overflow:hidden;height:100%;display:flex;flex-direction:column}
.pricing-page .plan:hover{border-color:var(--p);box-shadow:var(--sh);transform:translateY(-4px)}
.pricing-page .plan.feat{border-color:var(--p);background:linear-gradient(160deg,#fafbff,#f5f0ff);box-shadow:var(--sh)}
.pricing-page .pbadge{position:absolute;top:1rem;right:1rem;background:var(--grad);color:#fff;font-size:.67rem;font-weight:700;padding:.2rem .55rem;border-radius:100px}
.pricing-page .pn{font-size:1rem;font-weight:700;margin-bottom:.35rem}
.pricing-page .pp{font-size:2.1rem;font-weight:800;line-height:1;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.15rem}
.pricing-page .pp span{font-size:.87rem;font-weight:500;color:var(--muted);-webkit-text-fill-color:var(--muted)}
.pricing-page .pd{font-size:.82rem;color:var(--muted);margin-bottom:1.1rem;padding-bottom:1.1rem;border-bottom:1px solid var(--border)}
.pricing-page .pfl{list-style:none;padding:0;flex:1;margin:0}
.pricing-page .pfl li{display:flex;align-items:flex-start;gap:7px;font-size:.85rem;padding:.28rem 0}
.pricing-page .annual-saving{font-size:.8rem;color:var(--ok);font-weight:600;margin-bottom:.2rem}
.pricing-page .pcta{display:block;width:100%;margin-top:1.35rem;padding:.75rem;border-radius:var(--rs);font-size:.91rem;font-weight:700;text-align:center;text-decoration:none;transition:all .2s;cursor:pointer;line-height:1.4;border:none}
.pricing-page .pcta.pcp{background:var(--grad);color:#fff;box-shadow:0 4px 14px rgba(102,126,234,.35)}
.pricing-page .pcta.pcp:hover{transform:translateY(-2px);color:#fff}
.pricing-page .pcta.pco{background:transparent;color:var(--p);border:2px solid var(--p)}
.pricing-page .pcta.pco:hover{background:var(--gs);transform:translateY(-2px);color:var(--p)}
.pricing-page .pcta.active-plan{background:rgba(16,185,129,.1);color:#059669;border:2px solid rgba(16,185,129,.5);cursor:default}
.pricing-page .pcta.unavailable{background:var(--bg2);color:var(--muted);border:2px solid var(--border);cursor:not-allowed}
.pricing-page .pcta-form{margin-top:1.35rem}
.pricing-page .pcta-form .pcta{margin-top:0}
.pricing-page .altbg{background:var(--bg2);border-radius:24px;padding:3rem 3.5rem;margin-bottom:3rem}
.pricing-page .sec-card{background:#fff;border-radius:var(--r);padding:1.4rem;border:1px solid var(--border);transition:all .2s;height:100%}
.pricing-page .sec-card:hover{transform:translateY(-3px);box-shadow:var(--sh);border-color:rgba(102,126,234,.3)}
.pricing-page .sec-card h6{font-size:.92rem;font-weight:700;margin-bottom:.3rem}
.pricing-page .sec-card p{font-size:.83rem;color:var(--muted);margin:0;line-height:1.6}
.pricing-page .ctabg{background:var(--grad);border-radius:24px;padding:3.5rem;text-align:center;position:relative;overflow:hidden}
.pricing-page .ctabg::before{content:'';position:absolute;width:400px;height:400px;background:rgba(255,255,255,.05);border-radius:50%;top:-170px;right:-80px}
.pricing-page .ctabg h3{color:#fff;font-size:clamp(1.35rem,3vw,1.9rem);font-weight:800;margin-bottom:.7rem;position:relative;z-index:1}
.pricing-page .ctabg p{color:rgba(255,255,255,.83);font-size:.97rem;max-width:450px;margin:0 auto 1.5rem;position:relative;z-index:1}
.pricing-page .bw{background:#fff;color:var(--p);padding:.82rem 2rem;border-radius:var(--rs);font-size:.95rem;font-weight:700;text-decoration:none;display:inline-block;transition:all .2s;position:relative;z-index:1;box-shadow:0 4px 18px rgba(0,0,0,.14);border:none}
.pricing-page .bw:hover{transform:translateY(-2px);color:var(--p)}
@media(max-width:767.98px){.pricing-page .page-hero{padding:2rem 1.5rem}.pricing-page .altbg{padding:2rem 1.5rem}}

/* ── Dark mode: auth & pricing ── */
[data-bs-theme="dark"] .auth-page,[data-bs-theme="dark"] .pricing-page{--txt:var(--bs-body-color);--muted:var(--bs-secondary-color);--bg2:var(--bs-tertiary-bg);--border:var(--bs-border-color);--p:#8ba4f8;--pd:#a87fd4;--grad:linear-gradient(135deg,#8ba4f8,#a87fd4)}
[data-bs-theme="dark"] .auth-page .auth-wrap,[data-bs-theme="dark"] .pricing-page .page-hero{background:linear-gradient(160deg,rgba(102,126,234,.15),rgba(118,75,162,.1) 50%,rgba(16,185,129,.06))}
[data-bs-theme="dark"] .auth-page .auth-card,[data-bs-theme="dark"] .pricing-page .plan,[data-bs-theme="dark"] .pricing-page .sec-card{background:var(--bs-body-bg)}
[data-bs-theme="dark"] .auth-page .ttl-grad,[data-bs-theme="dark"] .pricing-page .ttl-grad{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
[data-bs-theme="dark"] .auth-page .step-section-label{color:#c4b5fd}
[data-bs-theme="dark"] .auth-page .req-item{color:rgba(255,255,255,.3)}
[data-bs-theme="dark"] .auth-page .req-item::before{color:rgba(255,255,255,.18)}
[data-bs-theme="dark"] .auth-page .req-item.met{color:#6ee7b7}
[data-bs-theme="dark"] .auth-page .req-item.met::before{color:var(--ok)}
[data-bs-theme="dark"] .pricing-page .plan.feat{background:linear-gradient(160deg,rgba(102,126,234,.15),rgba(118,75,162,.12))}
[data-bs-theme="dark"] .pricing-page .status-badge.ok{color:#6ee7b7}
[data-bs-theme="dark"] .pricing-page .status-badge.warn{color:#fcd34d}

/* ── Bootstrap brand alignment ── */
:root{
--bs-primary:#667eea;--bs-primary-rgb:102,126,234;
--bs-link-color:#667eea;--bs-link-hover-color:#764ba2;
}
[data-bs-theme="dark"]{
--bs-primary:#8ba4f8;--bs-primary-rgb:139,164,248;
--bs-link-color:#8ba4f8;--bs-link-hover-color:#a87fd4;
}

/* ── Authenticated app pages ── */
.app-page,.admin-main,.admin-sidebar{
--p:#667eea;--pd:#764ba2;--ok:#10b981;--warn:#f59e0b;--err:#ef4444;--txt:#1f2937;--muted:#6b7280;--bg2:#f9fafb;--border:#e5e7eb;
--grad:linear-gradient(135deg,#667eea,#764ba2);--gs:linear-gradient(135deg,rgba(102,126,234,.07),rgba(118,75,162,.07));
--sh:0 4px 16px rgba(102,126,234,.12),0 2px 6px rgba(0,0,0,.06);--r:16px;--rs:8px;
}
[data-bs-theme="dark"] .app-page,[data-bs-theme="dark"] .admin-main,[data-bs-theme="dark"] .admin-sidebar{
--p:#8ba4f8;--pd:#a87fd4;--txt:var(--bs-body-color);--muted:var(--bs-secondary-color);--bg2:var(--bs-tertiary-bg);--border:var(--bs-border-color);
--grad:linear-gradient(135deg,#8ba4f8,#a87fd4);
}
.app-page .page-hero{
background:var(--grad);border-radius:var(--r);padding:1.75rem 2rem;margin-bottom:1.5rem;color:#fff;position:relative;overflow:hidden;
box-shadow:0 8px 24px rgba(102,126,234,.28);
}
.app-page .page-hero::before{
content:'';position:absolute;width:320px;height:320px;background:rgba(255,255,255,.08);border-radius:50%;top:-120px;right:-60px;pointer-events:none;
}
.app-page .page-hero h1,.app-page .page-hero .h3{color:#fff;margin-bottom:.35rem;font-weight:800}
.app-page .page-hero p,.app-page .page-hero .hero-sub{color:rgba(255,255,255,.85);margin-bottom:0}
.app-page .page-hero .btn-outline-light{border-color:rgba(255,255,255,.55);color:#fff}
.app-page .page-hero .btn-outline-light:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}
.app-page .content-card{
background:var(--bs-body-bg,#fff);border:1px solid var(--border);border-radius:var(--r);
box-shadow:var(--sh);transition:transform .2s,box-shadow .2s;
}
.app-page .content-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(102,126,234,.16),0 2px 8px rgba(0,0,0,.06)}
.app-page .content-card .card-header{background:transparent;border-bottom:1px solid var(--border);font-weight:700}
.app-page .stat-icon{
width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;
background:var(--gs);color:var(--p);flex-shrink:0;
}
.app-page .ttl-grad{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.app-page .bp,.app-page .btn-brand-primary,.admin-main .btn-brand-primary{
background:var(--grad)!important;border:none!important;color:#fff!important;
box-shadow:0 4px 14px rgba(102,126,234,.35);font-weight:700;border-radius:var(--rs);
}
.app-page .bp:hover,.app-page .btn-brand-primary:hover,.admin-main .btn-brand-primary:hover{
transform:translateY(-1px);color:#fff!important;
}
.app-page .bo,.app-page .btn-brand-outline,.admin-main .btn-brand-outline{
background:transparent;color:var(--p)!important;border:2px solid var(--p)!important;
font-weight:700;border-radius:var(--rs);
}
.app-page .bo:hover,.app-page .btn-brand-outline:hover,.admin-main .btn-brand-outline:hover{background:var(--gs);color:var(--p)!important}
.app-page .form-control:focus,.app-page .form-select:focus,.admin-main .form-control:focus,.admin-main .form-select:focus{
border-color:var(--p);box-shadow:0 0 0 .2rem rgba(102,126,234,.18);
}
[data-bs-theme="dark"] .app-page .page-hero{box-shadow:0 8px 28px rgba(0,0,0,.35)}
[data-bs-theme="dark"] .app-page .content-card{background:var(--bs-body-bg)}

/* Nav section + app links — active state */
.presentation-nav-links a.active{color:var(--p);font-weight:700;position:relative}
.presentation-nav-links a.active::after{
content:'';position:absolute;left:0;right:0;bottom:-.35rem;height:2px;background:var(--grad);border-radius:2px;
}
[data-bs-theme="dark"] .presentation-nav-links a.active{color:var(--p)}

/* ── Admin panel brand (sidebar + accents) ── */
.admin-sidebar .admin-nav .nav-link.active,.admin-main .page-item.active .page-link{
background:var(--grad)!important;border-color:transparent!important;color:#fff!important;
box-shadow:0 2px 10px rgba(102,126,234,.35)!important;
}
.admin-sidebar .admin-nav .nav-link.active:hover,.admin-sidebar .admin-nav .nav-link.active:focus{
background:var(--grad)!important;color:#fff!important;
}
.admin-nav .nav-link:not(.active):hover,.admin-back-link:hover{color:var(--p)!important;background:var(--gs)!important}
.admin-page-header .admin-page-icon{background:var(--gs)!important;color:var(--p)!important}
.admin-main .card.bg-primary,.admin-main .card.bg-primary.text-white{background:var(--grad)!important;border:none!important}
[data-bs-theme="dark"] .admin-sidebar{background:#1a1a2e;border-color:#2d3a5f}
[data-bs-theme="dark"] .admin-mobile-bar{background:#1a1a2e;border-color:#2d3a5f}
[data-bs-theme="dark"] .admin-nav .nav-link:not(.active):hover{background:rgba(102,126,234,.12)!important;color:var(--p)!important}
[data-bs-theme="dark"] .admin-sidebar .admin-nav .nav-link.active{
background:var(--grad)!important;color:#fff!important;
box-shadow:0 2px 12px rgba(102,126,234,.35)!important;
}
.app-page .page-hero .breadcrumb-item a{color:rgba(255,255,255,.7)!important}
.app-page .page-hero .breadcrumb-item.active,.app-page .page-hero .breadcrumb-item+.breadcrumb-item::before{color:rgba(255,255,255,.9)!important}
[data-bs-theme="dark"] .admin-main .form-control:focus,[data-bs-theme="dark"] .admin-main .form-select:focus{
border-color:var(--p);box-shadow:0 0 0 .25rem rgba(139,164,248,.15);
}

/* ── Auth: 2FA OTP ── */
.auth-page .otp-input{
letter-spacing:.55em;font-size:2rem;font-weight:700;text-align:center;
border:2px solid rgba(102,126,234,.35)!important;border-radius:14px!important;
padding:1rem!important;transition:all .25s!important;
}
.auth-page .otp-input:focus{border-color:var(--p)!important;box-shadow:0 0 0 .2rem rgba(102,126,234,.18)!important}
.auth-page .backup-toggle{
background:var(--bg2);border:1px solid var(--border);border-radius:10px;
padding:.65rem 1rem;color:var(--muted);font-size:.83rem;cursor:pointer;width:100%;text-align:center;list-style:none;transition:background .2s,color .2s;
}
.auth-page .backup-toggle:hover{background:var(--gs);color:var(--p)}
.auth-page .backup-info{
margin-top:.75rem;background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);
border-radius:10px;padding:.75rem 1rem;font-size:.83rem;color:var(--muted);line-height:1.55;
}
.auth-page .auth-form-wrap{width:100%;max-width:420px}

/* ── Auth: reset password ── */
.auth-page .password-requirement{font-size:.85rem;margin:5px 0;transition:color .3s ease}
.auth-page .password-requirement.met{color:var(--ok)}
.auth-page .password-requirement i{margin-right:8px;width:14px}
.auth-page .strength-bar{height:6px;background:var(--bg2);border-radius:3px;overflow:hidden;margin-bottom:8px}
.auth-page .strength-bar-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:3px}

/* ── App: audit logs ── */
.app-page .details-container{max-width:300px}
.app-page .badge-sm{font-size:.7em}
.app-page .details-container .small{font-size:.8em;line-height:1.3}
.app-page .doc-beneficiary-chip{background:rgba(102,126,234,.12);color:var(--p);border:1px solid rgba(102,126,234,.25);font-weight:600;font-size:.75rem}
.app-page .doc-beneficiary-chip--empty{background:var(--bg2);color:var(--muted,#6c757d);border:1px solid var(--border)}
.app-page .doc-permission-chip{background:var(--bg2);color:var(--muted,#6c757d);border:1px solid var(--border);font-weight:500}
.app-page .doc-permission-chip--warn{background:rgba(245,158,11,.12);color:#b45309;border-color:rgba(245,158,11,.35)}
[data-bs-theme="dark"] .app-page .doc-beneficiary-chip--empty,[data-bs-theme="dark"] .app-page .doc-permission-chip{background:var(--bs-body-bg)}

/* ── Beneficiary token portal ── */
.beneficiary-portal .document-card{
border:1px solid var(--border);border-radius:var(--r);transition:all .2s;height:100%;
background:var(--bs-body-bg,#fff);
}
.beneficiary-portal .document-card:hover{transform:translateY(-3px);box-shadow:var(--sh);border-color:rgba(102,126,234,.3)}
.beneficiary-portal .beneficiary-info{background:var(--bg2);border-radius:var(--r);padding:1.25rem;margin-bottom:1.5rem;border:1px solid var(--border)}
.beneficiary-portal .document-preview{background:var(--bg2);border-radius:var(--r);padding:1.75rem;text-align:center;margin-bottom:1.5rem;border:1px solid var(--border)}
[data-bs-theme="dark"] .beneficiary-portal .document-card,[data-bs-theme="dark"] .beneficiary-portal .document-preview,[data-bs-theme="dark"] .beneficiary-portal .beneficiary-info{background:var(--bs-body-bg)}

/* ── Responsive: presentation, auth, app, admin ── */
@media(max-width:900px){
.presentation-page .hero{padding:3rem 1.25rem;min-height:auto}
.presentation-page section{padding:3.5rem 1.25rem}
.presentation-page .ftabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:thin;padding-bottom:.35rem}
.presentation-page .ftabs .tb{flex-shrink:0}
}
@media(max-width:767.98px){
.presentation-page .hero{padding:2.5rem 1rem}
.presentation-page section{padding:3rem 1rem}
.presentation-page .hb{flex-direction:column;align-items:stretch}
.presentation-page .hb .bp,.presentation-page .hb .bo{text-align:center;width:100%}
.presentation-page .ctabg{padding:2.5rem 1rem}
.presentation-page .hcard{max-width:100%}
.pricing-page .page-hero{padding:2rem 1rem;border-radius:16px}
.pricing-page .altbg{padding:2rem 1rem;border-radius:16px}
.pricing-page .ctabg{padding:2.5rem 1.25rem}
.app-page .page-hero{padding:1.35rem 1rem}
.app-page .page-hero h1,.app-page .page-hero .h2,.app-page .page-hero .h3{font-size:clamp(1.2rem,5vw,1.5rem)}
.app-page .page-hero .d-flex:not(.align-items-center){flex-wrap:wrap;gap:.5rem}
.app-page .alert.d-flex{align-items:flex-start!important;flex-wrap:wrap;gap:.5rem}
.app-page .alert.d-flex form,.app-page .alert.d-flex>.btn,.app-page .alert.d-flex .btn{margin-left:0!important;width:100%}
.app-page .table-responsive,.app-page .table-responsive-auto{-webkit-overflow-scrolling:touch;max-width:100%}
.app-page .upload-dropzone{padding:1.75rem 1rem!important}
.admin-main .table-responsive{-webkit-overflow-scrolling:touch;max-width:100%}
.admin-main .admin-page-header .d-flex{flex-wrap:wrap;gap:.5rem}
}
@media(max-width:575.98px){
.presentation-nav-inner{padding:.5rem .75rem;gap:.45rem}
.presentation-nav-logo{font-size:1rem}
.presentation-nav-cta{padding:.45rem .85rem;font-size:.78rem}
.presentation-nav-login{font-size:.82rem;padding:.45rem .15rem}
.presentation-nav-theme{width:2rem;height:2rem;flex-shrink:0}
.presentation-nav-actions{gap:.4rem}
.presentation-page .stats,.presentation-page .plans{gap:1rem}
.admin-main{padding:1rem .75rem!important}
.admin-main .card-header .d-flex{flex-wrap:wrap;gap:.5rem}
}
