/* ==========================================================================
   Atlas Works — Public Stylesheet
   Design system shared across all public pages.
   ========================================================================== */

:root{
  /* Brand */
  --accent:        #2563eb;
  --accent-dark:   #1d4ed8;
  --accent-wash:   #eff6ff;
  --accent-line:   #c7dbff;
  --accent-soft:   #dbeafe;

  /* Neutrals */
  --navy:          #0b1430;
  --navy-2:        #131c3f;
  --ink:           #0f172a;
  --slate:         #475569;
  --muted:         #64748b;
  --line:          #e2e8f0;
  --line-2:        #eef2f7;
  --bg:            #f8fafc;
  --bg-2:          #f1f5fb;
  --card:          #ffffff;

  /* Geometry */
  --radius-sm:     10px;
  --radius:        14px;
  --radius-lg:     22px;

  /* Shadow tiers */
  --shadow-1:      0 2px 6px rgba(15,23,42,.05), 0 1px 2px rgba(15,23,42,.04);
  --shadow-2:      0 10px 30px rgba(15,23,42,.08), 0 2px 6px rgba(15,23,42,.04);
  --shadow-3:      0 24px 60px rgba(15,23,42,.14), 0 8px 16px rgba(15,23,42,.06);

  /* Type */
  --display:       'Sora', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --body:          'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  /* Layout */
  --container:     1180px;
}

/* Reset */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--body);
  color:var(--ink);background:var(--bg);
  line-height:1.6;font-size:16px;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
button,input,textarea,select{font:inherit;color:inherit}
button{border:none;background:none;cursor:pointer}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
::selection{background:var(--accent-soft);color:var(--ink)}

.container{width:min(var(--container),calc(100% - 32px));margin-inline:auto}

/* Skip link */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;inset:10px auto auto 10px;padding:.6rem 1rem;background:var(--ink);color:#fff;z-index:9999;border-radius:8px}

/* ==========================================================================
   Utility bar
   ========================================================================== */
.utility-bar{
  background:var(--navy);color:rgba(255,255,255,.85);
  font-size:.82rem;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06);
}
.utility-bar .container{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.utility-bar a{color:rgba(255,255,255,.85);transition:color .15s}
.utility-bar a:hover{color:#fff}
.utility-left{display:flex;align-items:center;gap:8px}
.utility-right{display:flex;align-items:center;gap:18px}
.utility-right span,.utility-right a{display:inline-flex;align-items:center;gap:6px}
.utility-right svg{width:13px;height:13px;opacity:.85}
.pulse-dot{
  width:8px;height:8px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 0 rgba(34,197,94,.6);animation:pulse-ring 2s infinite;
}
@keyframes pulse-ring{
  0%{box-shadow:0 0 0 0 rgba(34,197,94,.6)}
  70%{box-shadow:0 0 0 8px rgba(34,197,94,0)}
  100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}
}
@media (max-width:640px){
  .utility-left .label{display:none}
  .utility-right .hide-mobile{display:none}
}

/* ==========================================================================
   Header / Nav
   ========================================================================== */
.site-shell{display:flex;flex-direction:column;min-height:100vh}
.site-shell > main{flex:1}

.header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.navbar{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:72px;padding:14px 0;position:relative}

.brand{display:inline-flex;align-items:center;gap:10px;flex-shrink:0}
.brand:hover{text-decoration:none}
.brand-logo{
  width:42px;height:42px;border-radius:11px;
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:700;font-size:1.15rem;
  box-shadow:0 4px 12px rgba(37,99,235,.3);letter-spacing:-.02em;
}
.brand-block{display:flex;flex-direction:column;line-height:1.15}
.brand-mark{font-family:var(--display);font-size:1.05rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.brand-mark span{color:var(--accent)}
.brand-sub{font-size:.74rem;color:var(--muted);font-weight:500;letter-spacing:.01em}

.nav{display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:center}
.nav a{
  display:inline-flex;align-items:center;
  padding:.55rem .85rem;border-radius:8px;
  font-size:.92rem;font-weight:500;color:var(--slate);
  transition:color .15s,background .15s;position:relative;
}
.nav a:hover{color:var(--ink);background:var(--bg-2);text-decoration:none}
.nav a.is-active{color:var(--accent);background:var(--accent-wash);font-weight:600}

.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}

/* Hamburger */
.nav-toggle{
  display:none;width:42px;height:42px;border-radius:10px;
  border:1px solid var(--line);background:#fff;
  flex-direction:column;align-items:center;justify-content:center;gap:4px;
}
.nav-toggle span{width:18px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* Mobile menu */
.mobile-menu{
  display:none;position:absolute;left:0;right:0;top:100%;
  background:#fff;border-top:1px solid var(--line);
  box-shadow:0 16px 40px rgba(15,23,42,.08);
  padding:14px 16px 18px;
}
.mobile-menu.open{display:block}
.mobile-menu a{
  display:block;padding:11px 14px;border-radius:8px;
  font-weight:500;color:var(--ink);font-size:.96rem;
}
.mobile-menu a:hover{background:var(--bg-2);text-decoration:none}
.mobile-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line-2)}
.mobile-actions .btn{flex:1}

@media (max-width:1024px){
  .nav,.nav-actions{display:none}
  .nav-toggle{display:flex}
}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:.7rem 1.2rem;border-radius:10px;border:1.5px solid transparent;
  font-family:var(--body);font-weight:600;font-size:.94rem;line-height:1;
  cursor:pointer;transition:transform .15s,box-shadow .15s,background .15s,color .15s,border-color .15s;
  text-decoration:none;white-space:nowrap;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}

.btn-primary{
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;
  box-shadow:0 4px 12px rgba(37,99,235,.25);
}
.btn-primary:hover{box-shadow:0 8px 20px rgba(37,99,235,.35);color:#fff}

.btn-secondary{
  background:#fff;color:var(--ink);border-color:var(--line);
  box-shadow:var(--shadow-1);
}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}

.btn-large{padding:.85rem 1.5rem;font-size:1rem}

/* ==========================================================================
   Section primitives
   ========================================================================== */
.section{padding:80px 0}
@media (max-width:760px){.section{padding:56px 0}}
.section-alt{background:var(--bg-2)}

.section-head{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:end;margin-bottom:40px}
.section-head-actions{align-items:center}
@media (max-width:760px){.section-head{grid-template-columns:1fr;gap:14px;margin-bottom:28px}}
.section-eyebrow,.section-label{
  display:inline-block;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--accent);font-weight:700;margin-bottom:10px;
}
.section-title,.section-head h2{
  font-family:var(--display);font-weight:700;
  font-size:clamp(1.6rem,3.2vw,2.4rem);line-height:1.2;letter-spacing:-.02em;
  color:var(--ink);margin:0;
}
.section-intro,.section-lede{
  color:var(--muted);font-size:1.02rem;line-height:1.65;margin:0;max-width:60ch;
}
.section-actions{display:flex;flex-direction:column;align-items:flex-end;gap:14px}
@media (max-width:760px){.section-actions{align-items:flex-start}}

/* ==========================================================================
   Hero (homepage)
   ========================================================================== */
.hero{
  position:relative;padding:90px 0 90px;overflow:hidden;
  background:linear-gradient(180deg,#fff 0%,var(--bg) 100%);
}
.hero::before{
  content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:
    radial-gradient(at 20% 10%,rgba(37,99,235,.06) 0px,transparent 50%),
    radial-gradient(at 90% 80%,rgba(37,99,235,.05) 0px,transparent 50%),
    linear-gradient(rgba(15,23,42,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(15,23,42,.04) 1px,transparent 1px);
  background-size:auto,auto,40px 40px,40px 40px;
}
.hero .container{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:60px;align-items:center}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr;gap:40px}}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;padding:6px 14px;
  background:#fff;border:1px solid var(--accent-line);border-radius:999px;
  font-size:.85rem;font-weight:600;color:var(--accent-dark);
  box-shadow:var(--shadow-1);margin-bottom:24px;
}
.hero-badge .pulse-dot{background:var(--accent)}

.hero-copy h1{
  font-family:var(--display);font-weight:700;
  font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.05;letter-spacing:-.03em;
  color:var(--ink);margin:0 0 20px;
}
.hero-copy h1 span,.hero-copy h1 .accent{
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-copy .lead{
  font-size:1.1rem;line-height:1.7;color:var(--slate);max-width:55ch;margin:0 0 28px;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}

.hero-points{display:grid;gap:10px;margin-bottom:28px}
.point{display:flex;align-items:flex-start;gap:10px;color:var(--ink);font-size:.96rem}
.point-icon{
  flex:0 0 22px;width:22px;height:22px;border-radius:50%;
  background:#dcfce7;color:#16a34a;
  display:grid;place-items:center;font-size:.7rem;font-weight:700;margin-top:1px;
}
.point-icon svg{width:12px;height:12px}

.hero-meta{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
}
@media (max-width:560px){.hero-meta{grid-template-columns:1fr}}
.hero-meta > div{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 16px;box-shadow:var(--shadow-1);
}
.hero-meta strong{
  display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);font-weight:700;margin-bottom:4px;
}
.hero-meta a,.hero-meta span{font-weight:600;color:var(--ink);font-size:.92rem}
.hero-meta a:hover{color:var(--accent)}

/* Hero panel (right side aside) */
.hero-panel{
  position:relative;background:linear-gradient(135deg,var(--navy),var(--navy-2));
  color:#fff;border-radius:var(--radius-lg);padding:34px 30px;
  box-shadow:var(--shadow-3);overflow:hidden;
}
.hero-panel::before{
  content:"";position:absolute;inset:0;opacity:.16;pointer-events:none;
  background-image:radial-gradient(circle at 1px 1px,#fff 1px,transparent 0);
  background-size:22px 22px;
}
.hero-panel > *{position:relative;z-index:1}
.panel-label{
  font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;
  color:rgba(255,255,255,.65);font-weight:700;margin-bottom:14px;
}
.hero-panel h2{
  font-family:var(--display);font-weight:600;font-size:1.35rem;line-height:1.3;
  letter-spacing:-.01em;margin:0 0 22px;color:#fff;
}
.panel-items{display:grid;gap:18px;margin-bottom:22px}
.panel-item b{
  display:block;font-family:var(--display);font-size:1rem;font-weight:600;
  color:#fff;margin-bottom:4px;
}
.panel-item p{margin:0;color:rgba(255,255,255,.78);font-size:.9rem;line-height:1.55}
.panel-footer{
  display:flex;flex-wrap:wrap;gap:8px;padding-top:18px;
  border-top:1px solid rgba(255,255,255,.12);
}
.panel-footer span{
  display:inline-flex;align-items:center;gap:6px;font-size:.78rem;
  color:rgba(255,255,255,.7);font-weight:500;
}
.panel-footer span::before{content:"•";color:var(--accent)}

/* ==========================================================================
   Page hero (sub-pages)
   ========================================================================== */
.page-hero{
  position:relative;padding:80px 0 70px;overflow:hidden;
  background:linear-gradient(135deg,var(--navy),var(--navy-2));
  color:#fff;
}
.page-hero::before{
  content:"";position:absolute;inset:0;opacity:.18;pointer-events:none;
  background-image:radial-gradient(circle at 1px 1px,#fff 1px,transparent 0);
  background-size:30px 30px;
}
.page-hero::after{
  content:"";position:absolute;top:-40%;right:-20%;width:60%;height:140%;
  background:radial-gradient(circle,rgba(37,99,235,.25) 0%,transparent 60%);
  pointer-events:none;
}
.page-hero .container{position:relative;z-index:1}
.crumb{
  display:inline-block;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;
  color:rgba(255,255,255,.7);font-weight:600;margin-bottom:14px;
}
.crumb a{color:rgba(255,255,255,.85)}
.crumb a:hover{color:#fff}
.page-hero h1{
  font-family:var(--display);font-weight:700;
  font-size:clamp(2rem,4.6vw,3.2rem);line-height:1.1;letter-spacing:-.02em;
  margin:0 0 16px;color:#fff;max-width:24ch;
}
.page-hero .section-intro,.page-hero__lede{
  font-size:1.08rem;line-height:1.65;color:rgba(255,255,255,.78);max-width:60ch;margin:0 0 24px;
}
.page-hero-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:40px;align-items:start;position:relative;z-index:1}
@media (max-width:980px){.page-hero-grid{grid-template-columns:1fr;gap:30px}}
.page-hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.center-actions{justify-content:center}
.page-copy-wide{max-width:780px;margin:0 auto;text-align:left}

/* The compact panel variant inside page-hero */
.compact-panel{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);box-shadow:none;backdrop-filter:blur(6px)}
.compact-panel::before{display:none}
.compact-items{gap:14px}

/* page-hero-single is centered, used for legal/error pages */
.page-hero-single{padding:80px 0 60px}
.page-hero-single .page-copy-wide{text-align:left}
.not-found-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);text-align:center;color:#fff;padding:50px 30px;border-radius:var(--radius-lg);max-width:600px;margin:30px auto 0}
.not-found-card h1{color:#fff}
.not-found-card p{color:rgba(255,255,255,.78)}

/* ==========================================================================
   Trust strip / band
   ========================================================================== */
.section-band{padding:50px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:760px){.band-grid{grid-template-columns:1fr;gap:14px}}
.band-card{padding:18px 20px;border-radius:var(--radius);background:var(--bg-2);border:1px solid var(--line)}
.band-kicker{
  display:block;font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--accent);font-weight:700;margin-bottom:6px;
}
.band-card p{margin:0;color:var(--ink);font-weight:500;line-height:1.5;font-size:.95rem}

.trust-strip{padding:36px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media (max-width:880px){.trust-grid{grid-template-columns:repeat(2,1fr);gap:18px}}
.trust-item{display:flex;align-items:center;gap:14px}
.trust-icon{
  flex:0 0 44px;width:44px;height:44px;border-radius:11px;
  background:var(--accent-wash);color:var(--accent);
  display:grid;place-items:center;
}
.trust-icon svg{width:22px;height:22px}
.trust-text strong{display:block;font-family:var(--display);font-weight:600;font-size:.98rem;color:var(--ink);line-height:1.2}
.trust-text span{display:block;font-size:.84rem;color:var(--muted);margin-top:2px}

/* ==========================================================================
   Card grids — services / approach / process
   ========================================================================== */
.card-grid{display:grid;gap:18px}
.card-grid-2{grid-template-columns:repeat(2,1fr)}
.card-grid-3{grid-template-columns:repeat(3,1fr)}
.card-grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:980px){.card-grid-3,.card-grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.card-grid-2,.card-grid-3,.card-grid-4{grid-template-columns:1fr}}

.service-card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow-1);
  transition:transform .25s,box-shadow .25s,border-color .25s;overflow:hidden;
}
.service-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .3s;
}
.service-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:var(--accent-line)}
.service-card:hover::before{transform:scaleY(1)}
.service-icon{
  width:46px;height:46px;border-radius:11px;background:var(--accent-wash);
  color:var(--accent);display:grid;place-items:center;margin-bottom:18px;
}
.service-icon svg{width:24px;height:24px}
.service-card h3{
  font-family:var(--display);font-weight:600;font-size:1.18rem;letter-spacing:-.005em;
  color:var(--ink);margin:0 0 10px;
}
.service-card p{color:var(--slate);font-size:.94rem;line-height:1.6;margin:0 0 14px}
.service-card ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px}
.service-card ul li{
  font-size:.8rem;font-weight:600;color:var(--accent-dark);
  padding:4px 10px;background:var(--accent-wash);border-radius:99px;
}
.service-card-featured{
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;border-color:transparent;
}
.service-card-featured::before{background:rgba(255,255,255,.5)}
.service-card-featured .service-icon{background:rgba(255,255,255,.18);color:#fff}
.service-card-featured h3,.service-card-featured p{color:#fff}
.service-card-featured p{color:rgba(255,255,255,.88)}
.service-card-featured ul li{background:rgba(255,255,255,.18);color:#fff}

/* Approach cards (numbered) */
.approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:50px}
@media (max-width:880px){.approach-grid{grid-template-columns:1fr}}
.approach-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:32px 28px;box-shadow:var(--shadow-1);position:relative;
}
.approach-number{
  font-family:var(--display);font-weight:700;font-size:2.6rem;letter-spacing:-.04em;
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1;margin-bottom:12px;
}
.approach-card h3{
  font-family:var(--display);font-weight:600;font-size:1.2rem;color:var(--ink);
  margin:0 0 8px;letter-spacing:-.005em;
}
.approach-card p{color:var(--slate);font-size:.94rem;line-height:1.6;margin:0}

/* Split panel under approach */
.split-panel{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow-1);
}
@media (max-width:880px){.split-panel{grid-template-columns:1fr}}
.split-copy{padding:36px 32px;background:linear-gradient(135deg,var(--accent-wash),#fff);border-right:1px solid var(--line)}
@media (max-width:880px){.split-copy{border-right:none;border-bottom:1px solid var(--line)}}
.split-copy h3{
  font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--ink);
  margin:0 0 14px;letter-spacing:-.01em;
}
.split-copy p{color:var(--slate);line-height:1.65;margin:0}
.split-list{display:grid;padding:8px 0}
.split-list > div{
  padding:18px 32px;border-bottom:1px solid var(--line-2);font-size:.95rem;color:var(--ink);
  display:flex;align-items:center;gap:12px;
}
.split-list > div::before{
  content:"";flex:0 0 6px;width:6px;height:6px;border-radius:50%;background:var(--accent);
}
.split-list > div:last-child{border-bottom:none}

/* Process timeline */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative}
@media (max-width:880px){.timeline{grid-template-columns:1fr;gap:16px}}
.timeline::before{
  content:"";position:absolute;top:30px;left:5%;right:5%;height:2px;
  background-image:linear-gradient(90deg,var(--accent-line) 50%,transparent 50%);
  background-size:14px 2px;background-repeat:repeat-x;z-index:0;
}
@media (max-width:880px){.timeline::before{display:none}}
.timeline-step{
  position:relative;z-index:1;text-align:center;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 22px;box-shadow:var(--shadow-1);
}
@media (max-width:880px){.timeline-step{text-align:left;display:flex;gap:18px;align-items:center}}
.timeline-index{
  display:inline-grid;place-items:center;width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;
  font-family:var(--display);font-weight:700;font-size:1.1rem;letter-spacing:-.02em;
  margin:0 auto 14px;box-shadow:0 6px 20px rgba(37,99,235,.3);
  border:4px solid #fff;
}
@media (max-width:880px){.timeline-index{flex:0 0 48px;width:48px;height:48px;margin:0;font-size:.95rem}}
.timeline-step h3{
  font-family:var(--display);font-weight:600;font-size:1.05rem;color:var(--ink);
  margin:0 0 8px;letter-spacing:-.005em;
}
.timeline-step p{color:var(--slate);font-size:.9rem;line-height:1.55;margin:0}

/* ==========================================================================
   Showcase grid (projects + blog cards)
   ========================================================================== */
.showcase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:980px){.showcase-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.showcase-grid{grid-template-columns:1fr}}

.content-card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  box-shadow:var(--shadow-1);
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.content-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:var(--accent-line)}
.content-card-link{position:absolute;inset:0;z-index:1;font-size:0;color:transparent}
.content-card-link:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;border-radius:var(--radius)}

.content-card-media{aspect-ratio:16/10;overflow:hidden;background:var(--bg-2);position:relative}
.content-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.content-card:hover .content-card-media img{transform:scale(1.04)}
.content-card-media.placeholder{
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent-wash),var(--bg-2));
}
.content-card-media.placeholder span{
  font-family:var(--display);font-weight:600;color:var(--accent);font-size:.95rem;letter-spacing:.02em;
}
.content-card-media.blog-placeholder{background:linear-gradient(135deg,var(--bg-2),#fff)}

.content-card-body{padding:22px 24px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.content-meta{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--muted);font-weight:500}
.content-meta .pill{
  display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;
  font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;
  background:var(--accent);color:#fff;
}
.content-meta .pill.subtle{background:var(--bg-2);color:var(--slate)}

.content-card-body h2,.content-card-body h3{
  font-family:var(--display);font-weight:600;font-size:1.18rem;line-height:1.3;
  letter-spacing:-.01em;color:var(--ink);margin:0;
}
.content-card-body p{
  color:var(--slate);font-size:.94rem;line-height:1.55;margin:0;flex:1;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.content-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.content-tags span{
  font-size:.74rem;font-weight:600;color:var(--accent-dark);
  padding:3px 9px;background:var(--accent-wash);border-radius:6px;letter-spacing:.01em;
}
.content-link-row{display:flex;align-items:center;justify-content:space-between;margin-top:6px}
.content-link{
  display:inline-flex;align-items:center;gap:5px;color:var(--accent);
  font-weight:600;font-size:.9rem;
}
.content-link::after{
  content:"→";display:inline-block;transition:transform .2s;font-weight:400;
}
.content-card:hover .content-link::after{transform:translateX(3px)}

.content-card-featured{border-color:var(--accent-line)}

.content-empty{
  text-align:center;padding:80px 20px;color:var(--muted);
  border:1.5px dashed var(--line);border-radius:var(--radius-lg);background:var(--bg-2);
}
.content-empty h2,.content-empty h3{
  font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--ink);
  margin:0 0 8px;
}

/* ==========================================================================
   FAQ
   ========================================================================== */
.faq-list{display:grid;gap:10px;max-width:880px}
.faq-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:border-color .2s,box-shadow .2s;
}
.faq-item.open{border-color:var(--accent-line);box-shadow:var(--shadow-1)}
.faq-question{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:18px 22px;font-family:var(--display);font-weight:600;font-size:1.02rem;
  color:var(--ink);text-align:left;line-height:1.4;background:#fff;
}
.faq-question:hover{background:var(--bg-2)}
.faq-icon{
  flex:0 0 28px;width:28px;height:28px;border-radius:50%;
  background:var(--accent-wash);color:var(--accent);
  display:grid;place-items:center;font-size:1.1rem;font-weight:600;line-height:1;
  transition:transform .2s,background .2s,color .2s;
}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--accent);color:#fff}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-answer p{padding:0 22px 20px;margin:0;color:var(--slate);line-height:1.65}

/* ==========================================================================
   CTA banner
   ========================================================================== */
.cta-banner{padding:60px 0}
.cta-banner__inner{
  position:relative;background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  border-radius:var(--radius-lg);padding:48px 50px;color:#fff;overflow:hidden;
  display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:center;
  box-shadow:0 24px 60px rgba(37,99,235,.3);
}
@media (max-width:760px){.cta-banner__inner{grid-template-columns:1fr;padding:36px 28px;text-align:center}}
.cta-banner__inner::before{
  content:"";position:absolute;inset:0;opacity:.16;pointer-events:none;
  background-image:radial-gradient(circle at 1px 1px,#fff 1px,transparent 0);
  background-size:24px 24px;
}
.cta-banner__inner > *{position:relative;z-index:1}
.cta-banner h2{
  font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3vw,2.1rem);
  letter-spacing:-.02em;line-height:1.2;margin:0 0 8px;color:#fff;
}
.cta-banner p{margin:0;color:rgba(255,255,255,.85);font-size:1.02rem}
.cta-banner__actions{display:flex;gap:10px;flex-wrap:wrap}
@media (max-width:760px){.cta-banner__actions{justify-content:center}}
.cta-banner .btn-primary{background:#fff;color:var(--accent-dark);box-shadow:0 4px 12px rgba(0,0,0,.15)}
.cta-banner .btn-primary:hover{box-shadow:0 8px 20px rgba(0,0,0,.25);color:var(--accent-dark)}
.cta-banner .btn-secondary{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.cta-banner .btn-secondary:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.7)}

/* ==========================================================================
   Contact section + form
   ========================================================================== */
.contact-section{background:var(--bg)}
.contact-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:24px;align-items:start}
@media (max-width:980px){.contact-grid{grid-template-columns:1fr}}

.contact-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-2);padding:32px;
}
@media (max-width:560px){.contact-card{padding:22px}}

#contactForm{display:grid;gap:16px;position:relative}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-weight:600;font-size:.88rem;color:var(--ink)}
.field input,.field textarea,.field select{
  width:100%;padding:.78rem .9rem;
  border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);
  transition:border-color .15s,box-shadow .15s;font-size:.96rem;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.15);
}
.field textarea{resize:vertical;min-height:140px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:560px){.field-row{grid-template-columns:1fr}}

.hp-wrap{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

.captcha-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.captcha-question{
  display:inline-flex;align-items:center;padding:.7rem 1rem;background:var(--bg-2);
  border:1.5px dashed var(--accent-line);border-radius:10px;
  font-family:var(--display);font-weight:700;color:var(--ink);font-size:1rem;
  font-variant-numeric:tabular-nums;
}
.captcha-row input{flex:1;min-width:120px;max-width:200px}

.form-actions{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.helper-text{font-size:.84rem;color:var(--muted);margin:0}
.helper-text-error{color:#dc2626}
.form-status{font-size:.92rem;margin:0;font-weight:500;min-height:1.2em}
.form-status.ok{color:#16a34a}
.form-status.bad{color:#dc2626}

.contact-side{display:grid;gap:16px}
.contact-detail-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 24px;box-shadow:var(--shadow-1);
}
.contact-detail-card h3{
  font-family:var(--display);font-weight:600;font-size:1rem;
  color:var(--ink);margin:0 0 8px;letter-spacing:-.005em;
}
.contact-detail-card p{color:var(--slate);font-size:.94rem;line-height:1.55;margin:0}
.contact-detail-card a{color:var(--accent);font-weight:500}
.contact-detail-card a:hover{color:var(--accent-dark);text-decoration:underline}

/* Success popup */
.success-popup{
  position:fixed;inset:0;background:rgba(11,20,48,.6);backdrop-filter:blur(4px);
  display:none;place-items:center;z-index:1000;padding:20px;
}
.success-popup.visible{display:grid}
.success-inner{
  background:#fff;border-radius:var(--radius-lg);padding:36px 32px;
  max-width:440px;width:100%;text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.3);position:relative;
}
.success-inner::before{
  content:"";display:block;width:64px;height:64px;border-radius:50%;
  background:#dcfce7 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2316a34a' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/30px no-repeat;
  margin:0 auto 16px;
}
.success-inner h3{
  font-family:var(--display);font-weight:700;font-size:1.4rem;
  color:var(--ink);margin:0 0 8px;letter-spacing:-.01em;
}
.success-inner p{color:var(--muted);margin:0 0 20px;font-size:.96rem}
.success-inner button{
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;
  padding:.7rem 1.4rem;border-radius:10px;font-weight:600;font-size:.94rem;
  box-shadow:0 4px 12px rgba(37,99,235,.25);
}
.success-inner button:hover{box-shadow:0 8px 20px rgba(37,99,235,.35)}

/* ==========================================================================
   Article (project + blog post) layout
   ========================================================================== */
.article-hero{
  position:relative;padding:80px 0 60px;overflow:hidden;
  background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;
}
.article-hero::before{
  content:"";position:absolute;inset:0;opacity:.18;pointer-events:none;
  background-image:radial-gradient(circle at 1px 1px,#fff 1px,transparent 0);
  background-size:30px 30px;
}
.article-hero .container{position:relative;z-index:1}
.article-hero-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:40px;align-items:start}
@media (max-width:980px){.article-hero-grid{grid-template-columns:1fr}}
.article-hero h1{
  font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,4.4vw,2.9rem);
  line-height:1.1;letter-spacing:-.02em;margin:0 0 16px;color:#fff;
}
.article-hero .section-intro{color:rgba(255,255,255,.82);font-size:1.06rem;line-height:1.65}
.hero-meta-row{margin-bottom:18px;color:rgba(255,255,255,.82)}
.hero-meta-row .pill{background:rgba(255,255,255,.16);color:#fff}
.hero-meta-row .pill.subtle{background:rgba(255,255,255,.1)}
.hero-tags{margin-top:18px}
.hero-tags span{background:rgba(255,255,255,.12);color:#fff}

.article-layout-section{padding:60px 0 80px;background:var(--bg)}
.article-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:50px;align-items:start}
@media (max-width:980px){.article-layout{grid-template-columns:1fr;gap:30px}}

.article-body{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:40px 44px;box-shadow:var(--shadow-1);
}
@media (max-width:560px){.article-body{padding:28px 24px}}

.article-cover{margin:-40px -44px 30px;border-radius:0;overflow:hidden}
@media (max-width:560px){.article-cover{margin:-28px -24px 24px}}
.article-cover img{width:100%;aspect-ratio:21/9;object-fit:cover;display:block}

.project-links{display:flex;gap:10px;flex-wrap:wrap;padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid var(--line-2)}

/* Prose content */
.prose-content{font-size:1.04rem;line-height:1.75;color:var(--ink)}
.prose-content > *:first-child{margin-top:0}
.prose-content > *:last-child{margin-bottom:0}
.prose-content h2{
  font-family:var(--display);font-weight:700;font-size:1.6rem;letter-spacing:-.01em;
  line-height:1.25;margin:42px 0 14px;color:var(--ink);scroll-margin-top:90px;
}
.prose-content h3{
  font-family:var(--display);font-weight:600;font-size:1.22rem;letter-spacing:-.005em;
  margin:30px 0 10px;color:var(--ink);scroll-margin-top:90px;
}
.prose-content p{margin:0 0 16px}
.prose-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
.prose-content a:hover{color:var(--accent-dark)}
.prose-content strong{color:var(--ink);font-weight:700}
.prose-content ul,.prose-content ol{margin:0 0 18px;padding-left:24px}
.prose-content li{margin:6px 0}
.prose-content blockquote{
  margin:22px 0;padding:16px 22px;border-left:4px solid var(--accent);background:var(--accent-wash);
  color:var(--ink);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-style:italic;
}
.prose-content blockquote p{margin:0}
.prose-content img{
  width:100%;border-radius:var(--radius);margin:24px 0;box-shadow:var(--shadow-1);
}
.prose-content code{
  font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:.92em;
  background:var(--bg-2);padding:2px 6px;border-radius:5px;border:1px solid var(--line);
}
.prose-content pre{
  background:var(--ink);color:#e2e8f0;padding:18px 20px;border-radius:var(--radius);
  overflow-x:auto;margin:22px 0;font-size:.9rem;line-height:1.55;
}
.prose-content pre code{background:transparent;border:none;padding:0;color:inherit}
.prose-content hr{border:none;border-top:1px solid var(--line);margin:32px 0}

/* Article sidebar */
.article-sidebar{position:sticky;top:90px;display:grid;gap:18px}
@media (max-width:980px){.article-sidebar{position:static}}
.sidebar-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 24px;box-shadow:var(--shadow-1);
}
.sidebar-card h3{
  font-family:var(--display);font-weight:600;font-size:1rem;
  color:var(--ink);margin:0 0 8px;letter-spacing:-.005em;
}
.sidebar-card p{color:var(--slate);font-size:.92rem;line-height:1.55;margin:0 0 14px}
.sidebar-actions{display:flex;flex-direction:column;gap:8px}
.sidebar-actions .btn{width:100%}
.sidebar-list{display:grid;gap:8px}
.sidebar-link-card{
  display:block;padding:14px 16px;background:var(--bg-2);border:1px solid var(--line-2);
  border-radius:10px;transition:border-color .15s,background .15s;
}
.sidebar-link-card:hover{border-color:var(--accent-line);background:var(--accent-wash);text-decoration:none}
.sidebar-link-date{
  display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;
  color:var(--muted);font-weight:600;margin-bottom:4px;
}
.sidebar-link-card strong{
  display:block;font-family:var(--display);font-weight:600;font-size:.96rem;
  color:var(--ink);line-height:1.35;
}

.legal-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:48px 44px;max-width:840px;margin:0 auto;box-shadow:var(--shadow-1);
}
@media (max-width:560px){.legal-card{padding:32px 24px}}

/* ==========================================================================
   Footer
   ========================================================================== */
.footer{background:var(--navy);color:rgba(255,255,255,.78);padding:60px 0 0;margin-top:auto}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:40px}
@media (max-width:880px){.footer-grid{grid-template-columns:repeat(2,1fr);gap:28px}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}

.footer-brand{
  font-family:var(--display);font-weight:700;font-size:1.3rem;letter-spacing:-.01em;
  color:#fff;margin-bottom:12px;
}
.footer-brand span{color:var(--accent)}
.footer-copy{font-size:.92rem;line-height:1.6;color:rgba(255,255,255,.65);margin:0 0 18px;max-width:38ch}
.footer-socials{display:flex;gap:8px}
.footer-socials a{
  width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);color:#fff;
  display:grid;place-items:center;transition:background .15s,transform .15s;
}
.footer-socials a:hover{background:rgba(255,255,255,.14);transform:translateY(-2px);text-decoration:none}
.footer-socials svg{width:16px;height:16px}

.footer h3{
  font-family:var(--display);font-weight:600;font-size:.84rem;text-transform:uppercase;
  letter-spacing:.08em;color:#fff;margin:0 0 16px;
}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.footer ul a{color:rgba(255,255,255,.7);font-size:.92rem;transition:color .15s}
.footer ul a:hover{color:#fff;text-decoration:none}
.footer ul span{color:rgba(255,255,255,.65);font-size:.92rem}

.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 0;color:rgba(255,255,255,.55);font-size:.86rem}
.footer-bottom-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.footer-bottom p{margin:0}
.footer-admin-link{
  color:rgba(255,255,255,.45);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;
  font-weight:500;
}
.footer-admin-link:hover{color:rgba(255,255,255,.7);text-decoration:none}

/* Mobile floating call/contact button */
.float-cta{
  display:none;position:fixed;bottom:18px;right:18px;z-index:90;
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;
  width:54px;height:54px;border-radius:50%;
  align-items:center;justify-content:center;
  box-shadow:0 12px 28px rgba(37,99,235,.4);transition:transform .15s;
}
.float-cta:hover{transform:scale(1.05);text-decoration:none;color:#fff}
.float-cta svg{width:22px;height:22px}
@media (max-width:760px){.float-cta{display:inline-flex}}

/* ==========================================================================
   Reveal-on-scroll
   ========================================================================== */
[data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
[data-reveal].is-visible{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
