/* =========================================
   JUSTWEB OS — ABOUT PAGE
   about.css  ·  about.php
   ========================================= */

:root {
    --red:       #D93025; --red-glow:rgba(217,48,37,.2); --red-soft:rgba(217,48,37,.1);
    --blue:      #1A56E8; --green:#00C96B; --green-dim:rgba(0,201,107,.55);
    --dark:      #0F1117; --dark-2:#161B27; --dark-3:#1C2235;
    --white:     #FFFFFF; --off-white:#F7F6F2; --cream:#F0EDE6;
    --ink:       #0E1018; --ink-mid:#374151; --ink-soft:#6B7280; --ink-faint:#9CA3AF;
    --font-b:    'Plus Jakarta Sans',sans-serif;
    --font-m:    'IBM Plex Mono',monospace;
    --ease:      cubic-bezier(0.16,1,0.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-b);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%} a{text-decoration:none;color:inherit}
.mono{font-family:var(--font-m)}
.container-wide{width:100%;max-width:1360px;margin:0 auto;padding:0 44px}
.c-red{color:var(--red)} .c-blue{color:var(--blue)}

.ab-btn-red{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:#fff;font-size:14px;font-weight:700;padding:15px 30px;border-radius:6px;border:none;transition:background .3s,transform .2s,box-shadow .3s;white-space:nowrap;cursor:pointer}
.ab-btn-red:hover{background:#b82920;transform:translateY(-2px);box-shadow:0 14px 36px var(--red-glow)}
.ab-btn-red .arr{font-size:16px;transition:transform .3s var(--ease)}
.ab-btn-red:hover .arr{transform:translate(2px,-2px)}
.ab-btn-ghost{display:inline-flex;align-items:center;color:rgba(255,255,255,.65);font-size:14px;font-weight:600;padding:14px 0;border-bottom:1.5px solid rgba(255,255,255,.22);transition:color .25s,border-color .25s}
.ab-btn-ghost:hover{color:#fff;border-color:rgba(255,255,255,.65)}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes dotPulse{0%{box-shadow:0 0 0 0 var(--green-dim)}60%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}


/* ══════════════════════════════════════════
   § 1  HERO — full height, editorial
   ══════════════════════════════════════════ */
.ab-hero{
    position:relative;min-height:100vh;display:flex;align-items:flex-end;
    background:var(--dark);overflow:hidden;
}
.ab-hero__photo{position:absolute;inset:0;z-index:0}
.ab-hero__photo img{width:100%;height:100%;object-fit:cover;opacity:.3;object-position:center 30%}
.ab-hero__photo-scrim{
    position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(15,17,23,.45) 0%,rgba(15,17,23,.2) 40%,rgba(15,17,23,.92) 85%,var(--dark) 100%);
}
.ab-hero__grain{
    position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.036;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size:180px;
}
.ab-hero__inner{
    position:relative;z-index:5;width:100%;
    padding-bottom:100px;padding-top:200px;
}
.ab-hero__eyebrow{
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--font-m);font-size:10px;letter-spacing:.18em;
    color:rgba(255,255,255,.38);margin-bottom:32px;
    animation:fadeUp .9s var(--ease) .1s both;
}
.ab-hero__eyebrow-dot{width:5px;height:5px;background:var(--green);border-radius:50%;box-shadow:0 0 0 0 var(--green-dim);animation:dotPulse 2.4s ease infinite}
.ab-hero__title{
    font-size:clamp(52px,8vw,120px);font-weight:800;letter-spacing:-.05em;
    color:#fff;line-height:.95;margin-bottom:36px;
    animation:fadeUp .9s var(--ease) .2s both;
}
.ab-hero__title em{font-style:normal;color:var(--red);display:block}
.ab-hero__sub{
    font-size:18px;font-weight:400;line-height:1.75;
    color:rgba(255,255,255,.52);max-width:600px;
    animation:fadeUp .9s var(--ease) .3s both;
}


/* ══════════════════════════════════════════
   § 2  MISSION — cream, large editorial
   ══════════════════════════════════════════ */
.ab-mission{background:var(--cream);padding:120px 0;border-top:1px solid rgba(0,0,0,.04)}
.ab-mission__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.ab-mission__label{
    font-family:var(--font-m);font-size:9px;letter-spacing:.22em;
    color:var(--red);text-transform:uppercase;display:block;margin-bottom:20px;
}
.ab-mission__statement{
    font-size:clamp(28px,3.5vw,46px);font-weight:800;letter-spacing:-.035em;
    line-height:1.15;color:var(--ink);margin-bottom:32px;
}
.ab-mission__statement em{font-style:normal;color:var(--blue)}
.ab-mission__body{font-size:15px;line-height:1.9;color:var(--ink-mid)}
.ab-mission__body p+p{margin-top:16px}

/* Photo stack */
.ab-mission__visual{position:relative;height:520px}
.ab-mission__img-main{
    position:absolute;right:0;top:0;
    width:78%;height:76%;border-radius:16px;overflow:hidden;
    box-shadow:0 32px 72px rgba(0,0,0,.14);
}
.ab-mission__img-main img{width:100%;height:100%;object-fit:cover}
.ab-mission__img-accent{
    position:absolute;left:0;bottom:0;
    width:52%;height:48%;border-radius:12px;overflow:hidden;
    box-shadow:0 24px 56px rgba(0,0,0,.16);
    border:4px solid var(--cream);
}
.ab-mission__img-accent img{width:100%;height:100%;object-fit:cover}
.ab-mission__badge{
    position:absolute;right:0;bottom:80px;
    background:var(--red);color:#fff;
    padding:14px 20px;border-radius:10px;
    display:flex;flex-direction:column;gap:4px;
    box-shadow:0 12px 32px var(--red-glow);
}
.ab-mission__badge-n{font-size:28px;font-weight:800;letter-spacing:-.03em;line-height:1}
.ab-mission__badge-l{font-family:var(--font-m);font-size:9px;letter-spacing:.14em;opacity:.8}


/* ══════════════════════════════════════════
   § 3  STATS ROW — white
   ══════════════════════════════════════════ */
.ab-stats{background:var(--white);padding:80px 0;border-top:1px solid rgba(0,0,0,.05)}
.ab-stats__row{
    display:flex;align-items:flex-start;
    border-top:1px solid rgba(0,0,0,.07);border-bottom:1px solid rgba(0,0,0,.07);
    padding:52px 0;
}
.ab-stat{flex:1;padding-right:48px}
.ab-stat-sep{width:1px;height:72px;background:rgba(0,0,0,.09);align-self:center;margin-right:48px;flex-shrink:0}
.ab-stat__n{font-size:clamp(40px,5vw,68px);font-weight:800;letter-spacing:-.045em;color:var(--ink);line-height:1;margin-bottom:8px}
.ab-stat__n sup{font-size:.42em;color:var(--red);font-weight:700;vertical-align:super}
.ab-stat__lbl{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mid);margin-bottom:8px}
.ab-stat > p{font-size:13px;line-height:1.65;color:var(--ink-soft);max-width:180px}


/* ══════════════════════════════════════════
   § 4  VALUES — dark, 3 cards
   ══════════════════════════════════════════ */
.ab-values{background:var(--dark-2);padding:100px 0;position:relative;overflow:hidden}
.ab-values::before{
    content:'';position:absolute;inset:0;
    background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
    background-size:80px 80px;pointer-events:none;
}
.ab-values__inner{position:relative;z-index:2}
.ab-values__hdr{margin-bottom:60px}
.ab-values__title{font-size:clamp(32px,4vw,56px);font-weight:800;letter-spacing:-.035em;color:#fff;margin-bottom:14px}
.ab-values__sub{font-size:15px;line-height:1.75;color:rgba(255,255,255,.45);max-width:560px}

.ab-values__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ab-value{
    padding:40px 36px;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.07);border-radius:14px;
    transition:background .3s,border-color .3s,transform .3s var(--ease);
}
.ab-value:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.14);transform:translateY(-4px)}
.ab-value__num{font-family:var(--font-m);font-size:10px;letter-spacing:.18em;color:var(--red);display:block;margin-bottom:20px}
.ab-value__title{font-size:20px;font-weight:700;color:#fff;letter-spacing:-.02em;margin-bottom:14px;line-height:1.2}
.ab-value__body{font-size:14px;line-height:1.8;color:rgba(255,255,255,.45)}


/* ══════════════════════════════════════════
   § 5  WHY JUSTWEB — off-white, editorial grid
   ══════════════════════════════════════════ */
.ab-why{background:var(--off-white);padding:100px 0;border-top:1px solid rgba(0,0,0,.05)}
.ab-why__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.ab-why__sticky{position:sticky;top:120px}
.ab-why__label{font-family:var(--font-m);font-size:9px;letter-spacing:.22em;color:var(--red);display:block;margin-bottom:16px}
.ab-why__title{font-size:clamp(28px,3.5vw,48px);font-weight:800;letter-spacing:-.035em;color:var(--ink);line-height:1.1;margin-bottom:24px}
.ab-why__body{font-size:15px;line-height:1.85;color:var(--ink-mid)}

.ab-why__reasons{display:flex;flex-direction:column;gap:0}
.ab-reason{
    padding:32px 0;border-bottom:1px solid rgba(0,0,0,.07);
    display:flex;align-items:flex-start;gap:20px;
}
.ab-reason:first-child{border-top:1px solid rgba(0,0,0,.07)}
.ab-reason__num{font-family:var(--font-m);font-size:10px;letter-spacing:.14em;color:var(--red);flex-shrink:0;padding-top:4px}
.ab-reason__body h4{font-size:17px;font-weight:700;color:var(--ink);margin-bottom:8px;letter-spacing:-.015em}
.ab-reason__body p{font-size:14px;line-height:1.75;color:var(--ink-soft)}


/* ══════════════════════════════════════════
   § 6  CTA — dark
   ══════════════════════════════════════════ */
.ab-cta{background:var(--dark);padding:100px 0;position:relative;overflow:hidden}
.ab-cta__photo{position:absolute;inset:0;z-index:0}
.ab-cta__photo img{width:100%;height:100%;object-fit:cover;opacity:.15}
.ab-cta__photo-scrim{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,17,23,.92) 0%,rgba(22,27,39,.8) 100%)}
.ab-cta__inner{position:relative;z-index:5;text-align:center;max-width:720px;margin:0 auto}
.ab-cta__eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-m);font-size:9px;letter-spacing:.2em;color:rgba(255,255,255,.35);margin-bottom:28px}
.ab-cta__title{font-size:clamp(40px,6vw,80px);font-weight:800;letter-spacing:-.045em;color:#fff;line-height:1;margin-bottom:24px}
.ab-cta__title em{font-style:normal;color:var(--red)}
.ab-cta__body{font-size:16px;line-height:1.75;color:rgba(255,255,255,.5);margin-bottom:44px}
.ab-cta__actions{display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap}


/* RESPONSIVE */
@media(max-width:1100px){.container-wide{padding:0 28px}.ab-mission__grid{grid-template-columns:1fr;gap:48px}.ab-mission__visual{height:360px}.ab-stats__row{display:grid;grid-template-columns:1fr 1fr;gap:40px}.ab-stat-sep{display:none}.ab-values__grid{grid-template-columns:1fr 1fr}.ab-why__grid{grid-template-columns:1fr}.ab-why__sticky{position:static}}
@media(max-width:768px){.container-wide{padding:0 20px}.ab-hero__title{font-size:clamp(44px,11vw,64px)}.ab-mission__visual{height:280px}.ab-stats__row{grid-template-columns:1fr 1fr}.ab-values__grid{grid-template-columns:1fr}.ab-cta__actions{flex-direction:column;align-items:center}}
