/* ORP1 — Public Website CSS */

/* ── Top bar strip ── */
.topbar-strip {
    background: #0f172a;
    border-bottom: 1px solid rgba(255,255,255,.06);
    padding: 7px 0;
    font-size: 12.5px;
}
.topbar-strip .container { display:flex; align-items:center; justify-content:space-between; gap:16px; }
.topbar-left, .topbar-right { display:flex; align-items:center; gap:18px; }
.topbar-left a, .topbar-left span,
.topbar-right span { color:rgba(255,255,255,.65); display:flex; align-items:center; gap:6px; text-decoration:none; white-space:nowrap; transition:color .15s; }
.topbar-left a:hover { color:#fff; }
.topbar-left i, .topbar-right i { font-size:11px; }
.topbar-social { display:flex; gap:10px; }
.topbar-social a { color:rgba(255,255,255,.5); font-size:13px; transition:color .15s; }
.topbar-social a:hover { color:#fff; }
@media(max-width:768px) {
    .topbar-strip .topbar-right { display:none; }
    .topbar-left { gap:14px; }
    .topbar-left span { display:none; }
}
@media(max-width:480px) {
    .topbar-strip { display:none; }
}

:root {
    --primary: #2563eb;
    --primary-dark: #1d4ed8;
    --primary-light: #eff6ff;
    --accent: #7c3aed;
    --dark: #0f172a;
    --text: #334155;
    --muted: #64748b;
    --border: #e2e8f0;
    --bg: #f8fafc;
    --white: #ffffff;
    --success: #10b981;
    --radius: 12px;
    --shadow: 0 4px 24px rgba(0,0,0,.07);
    --shadow-lg: 0 12px 48px rgba(0,0,0,.12);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Inter','Segoe UI',sans-serif;color:var(--text);line-height:1.6;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}

/* ── Typography ── */
h1,h2,h3,h4{color:var(--dark);font-weight:700;line-height:1.2;}
h1{font-size:clamp(2.2rem,5vw,3.8rem);}
h2{font-size:clamp(1.8rem,4vw,2.8rem);}
h3{font-size:1.3rem;}
p{color:var(--text);}

/* ── Layout ── */
.container{max-width:1200px;margin:0 auto;padding:0 24px;}
.section{padding:80px 0;}
.section-sm{padding:48px 0;}
.section-header{text-align:center;margin-bottom:56px;}
.section-header p{font-size:1.1rem;color:var(--muted);margin-top:12px;max-width:600px;margin-left:auto;margin-right:auto;}
.badge{display:inline-block;background:var(--primary-light);color:var(--primary);padding:4px 14px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px;}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;border:none;transition:all .2s;white-space:nowrap;}
.btn-primary{background:var(--primary);color:#fff;}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(37,99,235,.35);}
.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary);}
.btn-outline:hover{background:var(--primary);color:#fff;}
.btn-white{background:#fff;color:var(--primary);}
.btn-white:hover{background:var(--primary-light);}
.btn-dark{background:var(--dark);color:#fff;}
.btn-dark:hover{background:#1e293b;}
.btn-lg{padding:16px 36px;font-size:16px;border-radius:10px;}
.btn-sm{padding:8px 18px;font-size:13px;}
.btn-group{display:flex;gap:12px;flex-wrap:wrap;}

/* ── Navbar ── */
.navbar{position:sticky;top:0;z-index:200;background:#fff;border-bottom:1px solid var(--border);padding:0;}
.navbar-inner{display:flex;align-items:center;height:68px;gap:32px;}
.navbar-brand{font-size:22px;font-weight:800;color:var(--primary);letter-spacing:-.5px;flex-shrink:0;}
.navbar-brand span{color:var(--accent);}
.navbar-nav{display:flex;align-items:center;gap:4px;flex:1;}
.navbar-nav a{padding:8px 14px;border-radius:8px;font-size:14px;font-weight:500;color:var(--text);transition:all .15s;}
.navbar-nav a:hover,.navbar-nav a.active{background:var(--primary-light);color:var(--primary);}
.navbar-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--text);}
.hamburger i{font-size:22px;}

/* ── Mobile nav ── */
.mobile-menu{display:none;position:fixed;inset:0;z-index:300;pointer-events:none;}
.mobile-menu.open{display:block;pointer-events:auto;}
.mobile-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);}
.mobile-panel{position:absolute;left:0;top:0;bottom:0;width:280px;background:#fff;padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;}
.mobile-panel .brand{font-size:20px;font-weight:800;color:var(--primary);margin-bottom:16px;}
.mobile-panel a{display:block;padding:12px 16px;border-radius:8px;font-weight:500;color:var(--text);}
.mobile-panel a:hover{background:var(--primary-light);color:var(--primary);}
.mobile-panel .divider{height:1px;background:var(--border);margin:12px 0;}

/* ── Hero ── */
.hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#1d4ed8 100%);color:#fff;padding:100px 0 80px;overflow:hidden;position:relative;}
.hero::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:6px 16px;font-size:13px;color:rgba(255,255,255,.9);margin-bottom:20px;}
.hero h1{color:#fff;margin-bottom:20px;}
.hero h1 span{color:#60a5fa;}
.hero p{color:rgba(255,255,255,.8);font-size:1.15rem;margin-bottom:32px;max-width:520px;}
.hero-stats{display:flex;gap:32px;margin-top:40px;padding-top:32px;border-top:1px solid rgba(255,255,255,.15);}
.hero-stat strong{display:block;font-size:1.8rem;font-weight:800;color:#fff;}
.hero-stat span{font-size:13px;color:rgba(255,255,255,.6);}
.hero-visual{display:flex;justify-content:center;align-items:center;}
.dashboard-preview{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:20px;backdrop-filter:blur(10px);}
.dash-topbar{height:36px;background:rgba(255,255,255,.08);border-radius:8px;margin-bottom:16px;display:flex;align-items:center;padding:0 12px;gap:8px;}
.dash-dot{width:10px;height:10px;border-radius:50%;}
.dash-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px;}
.dash-stat-box{background:rgba(255,255,255,.08);border-radius:8px;padding:12px;text-align:center;}
.dash-stat-box strong{display:block;font-size:18px;color:#fff;font-weight:700;}
.dash-stat-box span{font-size:11px;color:rgba(255,255,255,.5);}
.dash-chart{height:80px;background:rgba(255,255,255,.05);border-radius:8px;display:flex;align-items:flex-end;gap:4px;padding:8px;}
.dash-bar{flex:1;border-radius:4px 4px 0 0;background:linear-gradient(180deg,#60a5fa,#2563eb);}
.dash-table{margin-top:12px;}
.dash-row{height:24px;background:rgba(255,255,255,.06);border-radius:4px;margin-bottom:6px;}

/* ── Feature cards ── */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.feature-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:32px;transition:all .2s;}
.feature-card:hover{border-color:var(--primary);box-shadow:var(--shadow-lg);transform:translateY(-4px);}
.feature-icon{width:52px;height:52px;border-radius:12px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:18px;}
.feature-card h3{margin-bottom:10px;}
.feature-card p{color:var(--muted);font-size:14px;}

/* ── Modules grid ── */
.modules-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.module-item{background:#fff;border:1px solid var(--border);border-radius:10px;padding:20px;text-align:center;transition:all .2s;cursor:default;}
.module-item:hover{border-color:var(--primary);background:var(--primary-light);}
.module-item .icon{font-size:28px;margin-bottom:10px;}
.module-item span{font-size:13px;font-weight:600;color:var(--dark);}

/* ── How it works ── */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;position:relative;}
.steps-grid::before{content:'';position:absolute;top:28px;left:10%;right:10%;height:2px;background:linear-gradient(90deg,var(--primary),var(--accent));opacity:.2;}
.step-item{text-align:center;}
.step-num{width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 4px 16px rgba(37,99,235,.35);position:relative;z-index:1;}
.step-item h3{margin-bottom:8px;}
.step-item p{color:var(--muted);font-size:13.5px;}

/* ── Pricing ── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start;}
.price-card{background:#fff;border:2px solid var(--border);border-radius:16px;padding:36px;transition:all .2s;position:relative;}
.price-card:hover{border-color:var(--primary);box-shadow:var(--shadow-lg);}
.price-card.popular{border-color:var(--primary);box-shadow:0 8px 32px rgba(37,99,235,.15);}
.price-card .popular-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;padding:4px 20px;border-radius:20px;font-size:12px;font-weight:700;}
.price-card h3{font-size:1.3rem;margin-bottom:8px;}
.price-card .price{font-size:2.8rem;font-weight:800;color:var(--primary);margin:20px 0 4px;line-height:1;}
.price-card .price sub{font-size:1rem;font-weight:400;color:var(--muted);}
.price-card .price-desc{font-size:13px;color:var(--muted);margin-bottom:24px;}
.price-features{list-style:none;margin-bottom:28px;}
.price-features li{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:14px;border-bottom:1px solid var(--border);}
.price-features li:last-child{border-bottom:none;}
.price-features li i{color:var(--success);font-size:13px;width:16px;flex-shrink:0;}

/* ── Demo section ── */
.demo-tabs{display:flex;gap:8px;margin-bottom:32px;flex-wrap:wrap;}
.demo-tab{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;border:2px solid var(--border);background:#fff;color:var(--text);transition:all .15s;}
.demo-tab.active,.demo-tab:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light);}
.demo-panel{display:none;}
.demo-panel.active{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;}
.demo-screen{background:var(--dark);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-lg);}
.demo-screen-bar{background:#1e293b;padding:10px 14px;display:flex;align-items:center;gap:6px;}
.demo-screen-dot{width:10px;height:10px;border-radius:50%;}
.demo-screen-body{padding:16px;}
.demo-mock-header{height:32px;background:#1e293b;border-radius:6px;margin-bottom:12px;}
.demo-mock-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;}
.demo-mock-card{height:64px;background:#1e293b;border-radius:8px;}
.demo-mock-table .demo-mock-row{height:28px;background:#1e293b;border-radius:4px;margin-bottom:6px;opacity:.8;}
.demo-mock-table .demo-mock-row:nth-child(2){opacity:.6;}
.demo-mock-table .demo-mock-row:nth-child(3){opacity:.4;}
.demo-info h3{font-size:1.4rem;margin-bottom:12px;}
.demo-info p{color:var(--muted);margin-bottom:20px;font-size:15px;}
.demo-feature-list{list-style:none;margin-bottom:24px;}
.demo-feature-list li{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:14px;}
.demo-feature-list li i{color:var(--primary);width:16px;}

/* ── Testimonials ── */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.testimonial-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;}
.testimonial-stars{color:#f59e0b;font-size:14px;margin-bottom:14px;}
.testimonial-card p{color:var(--text);font-size:14px;line-height:1.7;margin-bottom:20px;}
.testimonial-author{display:flex;align-items:center;gap:12px;}
.testimonial-avatar{width:42px;height:42px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;}
.testimonial-author strong{display:block;font-size:14px;}
.testimonial-author span{font-size:12px;color:var(--muted);}

/* ── CTA ── */
.cta-section{background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);padding:80px 0;text-align:center;color:#fff;}
.cta-section h2{color:#fff;margin-bottom:16px;}
.cta-section p{color:rgba(255,255,255,.85);font-size:1.1rem;margin-bottom:32px;}

/* ── Doc page ── */
.doc-layout{display:grid;grid-template-columns:260px 1fr;gap:40px;align-items:start;}
.doc-sidebar{position:sticky;top:88px;}
.doc-sidebar h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px;margin-top:20px;}
.doc-sidebar h4:first-child{margin-top:0;}
.doc-sidebar a{display:block;padding:7px 12px;border-radius:6px;font-size:14px;color:var(--text);}
.doc-sidebar a:hover,.doc-sidebar a.active{background:var(--primary-light);color:var(--primary);}
.doc-content h1{margin-bottom:8px;}
.doc-content .lead{font-size:1.1rem;color:var(--muted);margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border);}
.doc-content h2{margin-top:40px;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--border);}
.doc-content h3{margin-top:28px;margin-bottom:12px;color:var(--primary);}
.doc-content p,.doc-content li{font-size:15px;color:var(--text);margin-bottom:10px;line-height:1.7;}
.doc-content ul,.doc-content ol{padding-left:24px;margin-bottom:16px;}
.doc-content code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-size:13px;font-family:monospace;color:#e11d48;}
.doc-content pre{background:var(--dark);color:#e2e8f0;padding:20px;border-radius:10px;overflow-x:auto;font-size:13px;line-height:1.7;margin:16px 0;}
.doc-content .callout{background:var(--primary-light);border-left:4px solid var(--primary);padding:16px 20px;border-radius:0 8px 8px 0;margin:20px 0;}
.doc-content .callout p{margin:0;color:var(--dark);}
.doc-content table{width:100%;border-collapse:collapse;margin:20px 0;font-size:14px;}
.doc-content table th{background:var(--bg);padding:10px 14px;text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:2px solid var(--border);}
.doc-content table td{padding:10px 14px;border-bottom:1px solid var(--border);}

/* ── Footer ── */
.site-footer{background:var(--dark);color:rgba(255,255,255,.7);padding:64px 0 32px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footer-brand{font-size:22px;font-weight:800;color:#fff;margin-bottom:12px;}
.footer-brand span{color:#60a5fa;}
.footer-desc{font-size:14px;line-height:1.7;margin-bottom:20px;}
.footer-social{display:flex;gap:10px;}
.footer-social a{width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);transition:all .15s;}
.footer-social a:hover{background:var(--primary);color:#fff;}
.footer-col h5{color:#fff;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:10px;}
.footer-col a{font-size:14px;color:rgba(255,255,255,.6);transition:color .15s;}
.footer-col a:hover{color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:13px;}

/* ── Responsive ── */
@media(max-width:1024px){
    .features-grid{grid-template-columns:repeat(2,1fr);}
    .modules-grid{grid-template-columns:repeat(3,1fr);}
    .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:768px){
    .hero-inner{grid-template-columns:1fr;}
    .hero-visual{display:none;}
    .features-grid{grid-template-columns:1fr;}
    .steps-grid{grid-template-columns:repeat(2,1fr);}
    .steps-grid::before{display:none;}
    .pricing-grid{grid-template-columns:1fr;}
    .modules-grid{grid-template-columns:repeat(2,1fr);}
    .testimonials-grid{grid-template-columns:1fr;}
    .doc-layout{grid-template-columns:1fr;}
    .doc-sidebar{display:none;}
    .demo-panel.active{grid-template-columns:1fr;}
    .demo-screen{order:2;}
    .footer-grid{grid-template-columns:1fr;}
    .footer-bottom{flex-direction:column;gap:12px;text-align:center;}
    .navbar-nav{display:none;}
    .navbar-actions{display:none;}
    .hamburger{display:flex;}
    .section{padding:56px 0;}
    /* Hero */
    .hero{padding:64px 0 48px;}
    .hero-stats{gap:20px;flex-wrap:wrap;}
    .hero-stat strong{font-size:1.4rem;}
    /* Buttons */
    .btn-group{flex-direction:column;align-items:flex-start;}
    .btn-lg{padding:14px 28px;font-size:15px;}
    /* Pricing */
    .price-card{padding:28px 22px;}
    /* Section header */
    .section-header{margin-bottom:36px;}
    /* Footer */
    .footer-social{flex-wrap:wrap;}
}
@media(max-width:480px){
    .container{padding:0 16px;}
    .section{padding:48px 0;}
    h1{font-size:clamp(1.8rem,8vw,2.8rem);}
    h2{font-size:clamp(1.5rem,6vw,2rem);}
    .modules-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
    .module-item{padding:14px 10px;}
    .module-item .icon{font-size:22px;}
    .module-item span{font-size:12px;}
    .steps-grid{grid-template-columns:1fr;}
    .hero-stats{gap:16px;}
    .btn{padding:11px 20px;font-size:14px;}
    .btn-group{align-items:stretch;}
    .btn-group .btn{justify-content:center;}
    /* Demo */
    .demo-tabs{gap:6px;}
    .demo-tab{padding:8px 14px;font-size:13px;}
    /* Testimonials */
    .testimonial-card{padding:22px 18px;}
    /* Pricing */
    .pricing-grid{gap:16px;}
    .price-card .price{font-size:2.2rem;}
}

/* ── Mobile menu auth buttons ── */
@media(max-width:768px){
    .mobile-panel .btn { display:flex; align-items:center; justify-content:center; width:100%; padding:13px; border-radius:10px; font-size:15px; font-weight:600; text-decoration:none; margin-top:4px; }
    .mobile-panel .btn-primary { background:var(--primary); color:#fff; border:none; }
    .mobile-panel .btn-outline  { background:transparent; color:var(--primary); border:2px solid var(--primary); }
}

/* ── Touch-friendly tap targets ── */
@media(max-width:768px){
    .navbar-nav a, .mobile-panel a { min-height:44px; display:flex; align-items:center; }
    .btn { min-height:44px; }
    input, select, textarea { min-height:44px; font-size:16px !important; } /* prevent iOS zoom */
}

/* ── Page-specific responsive fixes ── */

/* Features page */
@media(max-width:900px){
    .feat-hero { padding:70px 0 52px; }
    .spotlight { grid-template-columns:1fr !important; direction:ltr !important; }
    .spotlight-visual { display:none; }
    .features-grid { grid-template-columns:repeat(2,1fr); }
    .testimonials-grid { grid-template-columns:1fr; }
}
@media(max-width:560px){
    .features-grid { grid-template-columns:1fr; }
    .stats-bar-inner { flex-wrap:wrap; }
    .stat-item { flex:1 0 40%; border-right:none; border-bottom:1px solid var(--border); padding:12px 16px; }
    .stat-item:last-child { border-bottom:none; }
    .comp-table-wrap { margin:16px -16px 0; padding:0 16px; }
}

/* Documentation page */
@media(max-width:900px){
    .doc-page { flex-direction:column; }
    .doc-sidebar, .doc-toc { display:none; }
    .doc-main { padding:28px 20px 60px; max-width:100%; }
}

/* Contact page */
@media(max-width:900px){
    .contact-grid { grid-template-columns:1fr; }
    .channel-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:480px){
    .channel-grid { grid-template-columns:1fr; }
    .form-row { grid-template-columns:1fr; }
    .contact-hero { padding:64px 0 48px; }
}

/* Pricing page */
@media(max-width:900px){
    .plans-grid { grid-template-columns:1fr !important; max-width:440px; margin-left:auto; margin-right:auto; }
    .faq-grid   { grid-template-columns:1fr; }
}
@media(max-width:480px){
    .plans-grid { max-width:100%; }
    .compare-table-wrap { overflow-x:auto; margin:16px -16px 0; padding:0 16px; }
}

/* About page */
@media(max-width:900px){
    .story-grid    { grid-template-columns:1fr; }
    .story-visual  { display:none; }
    .values-grid   { grid-template-columns:repeat(2,1fr); }
    .about-stats-inner { flex-wrap:wrap; }
    .astat { flex:1 0 40%; border-right:none; border-bottom:1px solid var(--border); }
    .astat:last-child { border-bottom:none; }
}
@media(max-width:480px){
    .values-grid { grid-template-columns:1fr; }
    .astat { flex:1 0 100%; }
}

/* Support / Help */
@media(max-width:900px){
    .support-grid { grid-template-columns:1fr; }
    .channels { grid-template-columns:1fr 1fr; }
    .sla-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:480px){
    .channels { grid-template-columns:1fr; }
    .priority-row { grid-template-columns:1fr 1fr; }
    .form-row { grid-template-columns:1fr !important; }
}

/* Modules page */
@media(max-width:900px){
    .mods-grid { grid-template-columns:repeat(2,1fr); }
    .int-grid  { grid-template-columns:repeat(3,1fr); }
}
@media(max-width:560px){
    .mods-grid { grid-template-columns:1fr; }
    .int-grid  { grid-template-columns:repeat(2,1fr); }
    .filter-bar { gap:6px; }
    .ftab { padding:7px 14px; font-size:12px; }
}

/* Auth layout (register / login) */
@media(max-width:900px){
    .auth-left { display:none; }
    .auth-right { padding:32px 24px; align-items:flex-start; }
}
@media(max-width:480px){
    .auth-right { padding:24px 16px; }
    .fg-row { grid-template-columns:1fr !important; }
    .otp-grid input { width:38px; height:44px; font-size:18px; }
    .steps-bar { gap:4px; }
    .step-label { display:none; }
}

/* Demo page */
@media(max-width:900px){
    .demo-panel.active { grid-template-columns:1fr; }
    .demo-screen { order:2; }
}

/* Home page demo teaser grid */
@media(max-width:768px){
    .demo-teaser-grid { grid-template-columns:1fr !important; padding:36px 24px !important; gap:28px !important; }
    .demo-teaser-cards { grid-template-columns:repeat(2,1fr) !important; }
}
@media(max-width:480px){
    .demo-teaser-grid { padding:28px 18px !important; }
}

/* Utility */
.overflow-x-hidden { overflow-x:hidden; }
.w-full-mobile { }
@media(max-width:480px){
    .hide-mobile { display:none !important; }
    .show-mobile { display:block !important; }
}
