html, body { overflow-x: hidden; max-width: 100%;}
main {overflow-x: hidden; }
*, *::before, *::after { box-sizing: border-box;}

/* ---------- HERO ---------- */
.feat-hero{
    background: linear-gradient(135deg,#eaf4fc 0%,#f7fbff 60%,#ffffff 100%);
    padding: 70px 0 50px; position: relative; overflow: hidden;
}
.feat-hero::before{
    content:"";position:absolute;top:-80px;right:-80px;width:300px;height:300px;
    background:radial-gradient(circle,#bddef3 0%,transparent 70%);opacity:.6;
}
.feat-hero .eyebrow{
    display:inline-block;background:#fff;border:1px solid #d4e4f0;
    border-radius:999px;padding:6px 16px;font-size:.78rem;color:#0a5fa0;
    font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:18px;
    box-shadow:0 6px 20px rgba(13,131,221,.08);
}
.feat-hero h1{
    font-size: clamp(1.9rem, 4vw, 3rem);
    font-weight: 700; line-height: 1.18; letter-spacing:-.01em;
    color:#1c2733; margin:0 0 16px;
}
.feat-hero h1 .accent{color:#0d83dd}
.feat-hero p.lead{color:#5b6b7c;font-size:1.08rem;max-width:760px;margin:0 auto 26px}
.feat-hero .hero-stats{
    display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
    max-width:880px;margin:34px auto 0;
}
.feat-hero .hero-stat{
    background:#fff;border:1px solid #e6ecf2;border-radius:14px;
    padding:18px 14px;text-align:center;box-shadow:0 8px 22px rgba(13,131,221,.06);
}
.feat-hero .hero-stat .num{font-size:1.55rem;font-weight:800;color:#0d83dd;line-height:1}
.feat-hero .hero-stat .lbl{font-size:.82rem;color:#5b6b7c;margin-top:4px}
@media (max-width:700px){ .feat-hero .hero-stats{grid-template-columns:repeat(2,1fr)} }


@media (max-width: 575px){ .feat-mock-lg{ max-width: 100%; /* no fixed cap — respects viewport */ 
	aspect-ratio: 16 / 10; /* shorter box, fits narrow screens */ 
	border-radius: 16px; } 
	
	.feat-mock-lg > i{ 
		font-size: 3.4rem; 
		} /* down from 5.5rem */ 
	.feat-mock-lg .float-i{ padding: 6px 9px; font-size: 1rem; border-radius: 9px; } 
	.feat-mock-lg .float-i.t1{ top: 12px; left: 12px; } 
	.feat-mock-lg .float-i.t2{ bottom: 12px; right: 12px; } 
}

/* ---------- STICKY CATEGORY FILTER ---------- */
.cat-filter{
    background:#fff;
    border-top:1px solid #e6ecf2;border-bottom:1px solid #e6ecf2;
    padding:14px 0;
}
.cat-filter .pills{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:0;padding:0;list-style:none}
.cat-filter .pills a{
    display:inline-flex;align-items:center;gap:8px;
    padding:9px 18px;border-radius:999px;background:#f5f9fd;color:#1c2733;
    font-size:.88rem;font-weight:600;border:1px solid transparent;
    transition:all .18s ease;text-decoration:none;
}
.cat-filter .pills a:hover, .cat-filter .pills a.active{
    background:#0d83dd;color:#fff;border-color:#0d83dd;
}
.cat-filter .pills a i{font-size:1rem}

/* ---------- GROUP HEADER ---------- */
.feat-group{margin-top:60px}
.feat-group:first-of-type{margin-top:30px}
.feat-group .group-head{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.feat-group .group-head .num{
    background:#0d83dd;color:#fff;font-weight:700;font-size:.78rem;
    padding:6px 12px;border-radius:6px;letter-spacing:.08em;
}
.feat-group .group-head h3{
    font-size:1.55rem;margin:0;font-weight:700;letter-spacing:-.01em;color:#1c2733;
}
.feat-group .group-head .gline{flex:1;height:1px;background:linear-gradient(90deg,#bddef3,transparent)}

/* ============================================================
   NEW: ONE-FEATURE-PER-ROW LAYOUT
   ▸ Each feature renders as a full-width row.
   ▸ col-lg-5  = image (left)
   ▸ col-lg-7  = details (right)
   ▸ Alternating subtle background for legibility.
   ============================================================ */
.feat-row{
    padding: 48px 0;
    border-bottom: 1px solid #eef3f7;
    transition: background .25s ease;
}
.feat-row:last-of-type{border-bottom:none}
.feat-row:nth-child(even){background:#f9fcfe}
.feat-row:hover{background:#f5f9fd}

.feat-row-img{display:flex;align-items:center;justify-content:center}
.feat-mock-lg{
    width:100%;max-width:460px;aspect-ratio:4/3;
    background: linear-gradient(135deg,#eaf4fc,#ffffff);
    border:1px solid #e6ecf2;border-radius:22px;
    display:flex;align-items:center;justify-content:center;
    position:relative;overflow:hidden;
    box-shadow: 0 14px 32px rgba(13,131,221,.10);
    transition: transform .3s ease, box-shadow .3s ease;
}
.feat-mock-lg:hover{transform:translateY(-4px);box-shadow:0 20px 44px rgba(13,131,221,.18)}
.feat-mock-lg > i{font-size:5.5rem;color:#0d83dd}
.feat-mock-lg .float-i{
    position:absolute;background:#fff;border-radius:12px;
    padding:10px 14px;box-shadow:0 8px 22px rgba(13,131,221,.14);
    font-size:1.35rem;color:#0a5fa0;
}
.feat-mock-lg .float-i.t1{top:22px;left:22px}
.feat-mock-lg .float-i.t2{bottom:22px;right:22px}
.feat-mock-lg .float-i.t3{top:50%;right:18px;transform:translateY(-50%)}

.feat-row-body .icon-box{
    width:56px;height:56px;border-radius:14px;
    background:linear-gradient(135deg,#eaf4fc,#f7fbff);
    display:inline-flex;align-items:center;justify-content:center;
    margin-bottom:16px;
}
.feat-row-body .icon-box i{font-size:1.55rem;color:#0d83dd}
.feat-row-body h3.feat-title{
    font-size:1.6rem;font-weight:700;color:#1c2733;
    margin:0 0 14px;letter-spacing:-.01em;
}
.feat-row-body .desc{
    color:#5b6b7c;font-size:1rem;line-height:1.7;
    margin:0 0 18px;max-width:560px;
}
.feat-row-body .chiprow{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.feat-row-body .chip{
    background:#eaf4fc;color:#0a5fa0;font-size:.78rem;font-weight:600;
    padding:5px 12px;border-radius:999px;
}
.feat-row-body .more{
    color:#0d83dd;font-weight:600;font-size:.95rem;
    display:inline-flex;align-items:center;gap:6px;
}
.feat-row-body .more::after{content:"\2192";transition:transform .15s ease}
.feat-row-body .more:hover::after{transform:translateX(4px)}

@media (max-width: 991px){
    .feat-row{padding:30px 0}
    .feat-row-img{margin-bottom:22px}
    .feat-mock-lg{max-width:420px;margin:0 auto}
    .feat-row-body{text-align:left}
}

/* ---------- MID STATS, CTA STRIP, COMPARISON, WORKFLOW ---------- */
.mid-stats{
    background:linear-gradient(135deg,#0d83dd,#0a5fa0);color:#fff;
    border-radius:22px;padding:36px;margin:60px 0;
    display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;
    box-shadow:0 18px 40px rgba(13,131,221,.18);
}
.mid-stats .v{font-size:2rem;font-weight:800;line-height:1}
.mid-stats .l{font-size:.88rem;opacity:.9;margin-top:6px}
@media (max-width:760px){ .mid-stats{grid-template-columns:repeat(2,1fr)} }

.cta-strip{
    background:linear-gradient(135deg,#0d83dd,#0a5fa0);color:#fff;
    border-radius:22px;padding:44px 32px;margin:60px 0 20px;
    display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;
    box-shadow:0 18px 40px rgba(13,131,221,.18);
}
.cta-strip h3{font-size:1.6rem;font-weight:700;margin:0 0 6px}
.cta-strip p{margin:0;opacity:.92}
.cta-strip .demo-btn{background:#fff;color:#0a5fa0;border:none;padding:13px 24px;font-weight:700;border-radius:10px;display:inline-flex;align-items:center;gap:8px}
.cta-strip .demo-btn:hover{background:#ffd700;color:#0a5fa0}
@media (max-width:760px){ .cta-strip{grid-template-columns:1fr;text-align:center} }

.compare-band{padding:60px 0;background:#f5f9fd}
.compare-band h2{text-align:center;font-weight:700;margin-bottom:8px}
.compare-band .sub{text-align:center;color:#5b6b7c;margin-bottom:36px}
.compare-band .table-wrap{
    overflow-x: auto;                       /* table scrolls inside its own box */
    -webkit-overflow-scrolling: touch;
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(13,131,221,.08);
}
.compare-band table{
    width:100%;border-collapse:separate;border-spacing:0;
    background:#fff;
}
.compare-band th, .compare-band td{padding:14px 18px;text-align:left;border-bottom:1px solid #eef3f7;font-size:.94rem;white-space:nowrap}
.compare-band th{background:#0d83dd;color:#fff;font-weight:600}
.compare-band th.maple{background:#0a5fa0}
.compare-band td.cell-yes{color:#1b8d3a;font-weight:600}
.compare-band td.cell-no{color:#a8aebd}
.compare-band tr:last-child td{border-bottom:none}
@media (max-width: 575px){
    .compare-band th, .compare-band td{padding:10px 12px;font-size:.86rem}
}

.workflow{padding:60px 0}
.workflow .stage{
    background:#fff;border:1px solid #e6ecf2;border-radius:14px;padding:22px;text-align:center;
    position:relative;height:100%;
}
.workflow .stage .step-num{
    width:36px;height:36px;border-radius:50%;background:#0d83dd;color:#fff;
    display:flex;align-items:center;justify-content:center;font-weight:700;
    margin:0 auto 12px;
}
.workflow .stage i{font-size:1.6rem;color:#0d83dd;margin-bottom:8px;display:block}
.workflow .stage h5{font-weight:700;font-size:1rem;margin:0 0 6px}
.workflow .stage p{font-size:.85rem;color:#5b6b7c;margin:0}

.sec-head{text-align:center;max-width:780px;margin:0 auto 40px}
.sec-head h2{font-weight:700;font-size:clamp(1.6rem,3vw,2.2rem);margin:0 0 10px;color:#1c2733}
.sec-head p{color:#5b6b7c;margin:0}
.sec-head .ruler{width:60px;height:4px;background:#0d83dd;border-radius:4px;margin:12px auto 16px}