/* ============================================================
   PROWORK LLC — DESIGN SYSTEM
   ============================================================ */

/* -----------------------------
   Tokens
----------------------------- */
:root{
  /* Brand */
  --orange:#FF6B1F;
  --orange-dark:#E55A0F;
  --orange-light:#FFE9D9;
  --orange-glow:rgba(255,107,31,.35);

  /* Dark palette */
  --ink:#0A0E1A;
  --ink-2:#10172A;
  --ink-3:#1B2541;
  --ink-4:#27314D;

  /* Light palette */
  --paper:#FFFFFF;
  --paper-2:#F7F8FA;
  --paper-3:#EEF1F5;
  --line:#E4E7EC;

  /* Text */
  --text:#0F172A;
  --text-2:#475569;
  --text-3:#94A3B8;
  --text-inv:#FFFFFF;

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

  /* Radius */
  --r-sm:6px;
  --r-md:12px;
  --r-lg:20px;
  --r-xl:32px;
  --r-pill:999px;

  /* Shadow */
  --shadow-1:0 1px 2px rgba(15,23,42,.06);
  --shadow-2:0 6px 18px rgba(15,23,42,.08);
  --shadow-3:0 18px 48px rgba(15,23,42,.14);
  --shadow-4:0 32px 80px rgba(15,23,42,.22);
  --shadow-orange:0 18px 40px rgba(255,107,31,.32);

  /* Layout */
  --container:1280px;
  --container-md:1100px;
  --container-sm:900px;

  /* Motion */
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --t-fast:.2s;
  --t:.35s;
  --t-slow:.6s;

  /* Header */
  --header-h:96px;
  --header-h-sm:72px;
}

/* -----------------------------
   Reset
----------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  font-size:16px;line-height:1.65;
  color:var(--text);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;display:block;height:auto}
button,input,select,textarea{font:inherit;color:inherit}
button{background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none;transition:color var(--t-fast) var(--ease)}
ul{list-style:none}
::selection{background:var(--orange);color:#fff}

/* -----------------------------
   Typography
----------------------------- */
h1,h2,h3,h4,h5,h6{
  font-family:var(--f-display);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-.02em;
  color:var(--text);
}
h1{font-size:clamp(2.5rem,5.5vw,4.75rem);font-weight:800;letter-spacing:-.035em}
h2{font-size:clamp(2rem,4vw,3.25rem);font-weight:700}
h3{font-size:clamp(1.5rem,2.4vw,2.125rem)}
h4{font-size:clamp(1.25rem,1.6vw,1.5rem)}
h5{font-size:1.125rem}

p{color:var(--text-2)}
.lead{font-size:clamp(1.05rem,1.2vw,1.25rem);color:var(--text-2);line-height:1.7}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-display);
  font-size:.8125rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--orange);
}
.eyebrow::before{
  content:"";width:28px;height:2px;background:var(--orange);
}
.eyebrow.center{justify-content:center}

.section-title{margin-bottom:1rem}
.section-subtitle{max-width:640px;color:var(--text-2);font-size:1.05rem}
.center{text-align:center}
.center .section-subtitle{margin-left:auto;margin-right:auto}

/* -----------------------------
   Layout
----------------------------- */
.container{
  width:100%;max-width:var(--container);
  margin:0 auto;padding:0 24px;
}
.container-md{max-width:var(--container-md)}
.container-sm{max-width:var(--container-sm)}

.section{padding:clamp(64px,9vw,128px) 0}
.section-sm{padding:clamp(48px,6vw,80px) 0}
.section-tight{padding:clamp(48px,5vw,72px) 0}

/* -----------------------------
   Top utility bar
----------------------------- */
.topbar{
  background:var(--ink);
  color:var(--text-inv);
  font-size:.875rem;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:44px;gap:24px;flex-wrap:wrap;
}
.topbar-left{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.topbar-item{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.85)}
.topbar-item i,.topbar-item svg{color:var(--orange);width:16px;height:16px;flex-shrink:0}
.topbar-item:hover{color:var(--orange)}
.topbar-social{display:flex;align-items:center;gap:14px}
.topbar-social a{
  display:grid;place-items:center;width:30px;height:30px;
  border-radius:var(--r-sm);background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.8);
  transition:all var(--t-fast) var(--ease);
}
.topbar-social a:hover{background:var(--orange);color:#fff;transform:translateY(-2px)}
.topbar-social a svg{width:14px;height:14px}

/* -----------------------------
   Header / Nav
----------------------------- */
.header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:all var(--t) var(--ease);
}
.header.scrolled{box-shadow:var(--shadow-2)}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);gap:32px;
}
.brand{display:flex;align-items:center;flex-shrink:0}
.brand img{height:64px;width:auto}

.nav{display:flex;align-items:center;gap:4px}
.nav-item{position:relative}
.nav-link{
  display:inline-flex;align-items:center;gap:6px;
  padding:12px 16px;border-radius:var(--r-md);
  font-family:var(--f-display);
  font-weight:600;font-size:.95rem;
  color:var(--text);
  transition:all var(--t-fast) var(--ease);
}
.nav-link:hover,.nav-link.active{color:var(--orange);background:var(--orange-light)}
.nav-link .chev{width:14px;height:14px;opacity:.7;transition:transform var(--t-fast) var(--ease)}
.nav-item:hover .nav-link .chev{transform:rotate(180deg)}

.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;
  min-width:280px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-3);
  padding:10px;
  opacity:0;visibility:hidden;
  transform:translateY(8px);
  transition:all var(--t) var(--ease);
  z-index:50;
}
.nav-item:hover .dropdown,.nav-item:focus-within .dropdown{
  opacity:1;visibility:visible;transform:translateY(0);
}
.dropdown a{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;border-radius:var(--r-md);
  font-size:.9375rem;font-weight:500;
  color:var(--text);
  transition:all var(--t-fast) var(--ease);
}
.dropdown a:hover{background:var(--paper-2);color:var(--orange);transform:translateX(4px)}
.dropdown a svg{width:18px;height:18px;color:var(--orange);flex-shrink:0}

/* Mega dropdown */
.dropdown.mega{
  min-width:520px;
  display:grid;grid-template-columns:1fr 1fr;gap:6px;
  padding:14px;
}

.header-cta{display:flex;align-items:center;gap:14px}
.icon-btn{
  display:grid;place-items:center;width:42px;height:42px;
  border-radius:var(--r-md);
  background:var(--paper-2);
  color:var(--text);
  transition:all var(--t-fast) var(--ease);
}
.icon-btn:hover{background:var(--orange);color:#fff;transform:translateY(-2px)}
.icon-btn svg{width:18px;height:18px}

.burger{display:none;background:none;border:0;width:42px;height:42px;border-radius:var(--r-md);place-items:center;color:var(--text)}
.burger svg{width:24px;height:24px}

/* Mobile nav */
.mobile-nav{
  position:fixed;top:0;right:-100%;height:100vh;width:min(90vw,400px);
  background:#fff;z-index:200;
  padding:28px 24px;
  overflow-y:auto;
  box-shadow:var(--shadow-4);
  transition:right var(--t) var(--ease);
}
.mobile-nav.open{right:0}
.mobile-nav-overlay{
  position:fixed;inset:0;background:rgba(10,14,26,.5);
  backdrop-filter:blur(4px);
  z-index:150;opacity:0;visibility:hidden;
  transition:all var(--t) var(--ease);
}
.mobile-nav-overlay.open{opacity:1;visibility:visible}
.mobile-nav-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.mobile-nav-head img{height:48px}
.mobile-nav a.m-link{display:flex;align-items:center;justify-content:space-between;padding:14px 12px;border-radius:var(--r-md);font-family:var(--f-display);font-weight:600;font-size:1rem;color:var(--text)}
.mobile-nav a.m-link:hover,.mobile-nav details[open] summary.m-link{background:var(--paper-2);color:var(--orange)}
.mobile-nav details summary{list-style:none;cursor:pointer}
.mobile-nav details summary::-webkit-details-marker{display:none}
.mobile-nav details summary svg{transition:transform var(--t-fast) var(--ease);width:18px;height:18px}
.mobile-nav details[open] summary svg{transform:rotate(180deg)}
.mobile-nav details ul{padding:4px 12px 8px 28px}
.mobile-nav details ul a{display:block;padding:10px 12px;font-size:.95rem;color:var(--text-2);border-radius:var(--r-sm)}
.mobile-nav details ul a:hover{color:var(--orange);background:var(--paper-2)}
.mobile-cta{margin-top:18px}

/* -----------------------------
   Buttons
----------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 26px;border-radius:var(--r-md);
  font-family:var(--f-display);
  font-weight:600;font-size:.9375rem;
  letter-spacing:.01em;
  cursor:pointer;
  white-space:nowrap;
  transition:all var(--t) var(--ease);
  position:relative;overflow:hidden;
}
.btn svg{width:18px;height:18px;transition:transform var(--t-fast) var(--ease)}
.btn:hover svg.arrow{transform:translateX(4px)}

.btn-primary{
  background:var(--orange);color:#fff;
  box-shadow:var(--shadow-orange);
}
.btn-primary:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:0 22px 48px rgba(255,107,31,.4)}

.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink-2);transform:translateY(-2px)}

.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-2px)}

.btn-outline-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.25)}
.btn-outline-light:hover{background:#fff;color:var(--ink);border-color:#fff;transform:translateY(-2px)}

.btn-ghost{background:rgba(255,255,255,.08);color:#fff;backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}

.btn-lg{padding:18px 32px;font-size:1rem}
.btn-sm{padding:10px 18px;font-size:.875rem}
.btn-block{width:100%}

/* -----------------------------
   Hero
----------------------------- */
.hero{
  position:relative;
  background:var(--ink);
  color:#fff;
  overflow:hidden;
  padding:clamp(80px,12vw,160px) 0 clamp(80px,12vw,140px);
  min-height:88vh;display:flex;align-items:center;
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(255,107,31,.18), transparent 50%),
    radial-gradient(ellipse at 20% 80%, rgba(255,107,31,.08), transparent 50%),
    linear-gradient(135deg,#0A0E1A 0%,#10172A 60%,#1B2541 100%);
}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at center,black,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at center,black,transparent 70%);
}
.hero-blob{
  position:absolute;
  width:520px;height:520px;border-radius:50%;
  filter:blur(120px);opacity:.45;
  pointer-events:none;
}
.hero-blob.b1{background:#FF6B1F;top:-180px;right:-120px;animation:floatA 14s var(--ease) infinite alternate}
.hero-blob.b2{background:#3B5BFF;bottom:-200px;left:-100px;opacity:.25;animation:floatB 18s var(--ease) infinite alternate}
@keyframes floatA{from{transform:translate(0,0) scale(1)}to{transform:translate(-40px,40px) scale(1.08)}}
@keyframes floatB{from{transform:translate(0,0) scale(1)}to{transform:translate(60px,-30px) scale(1.12)}}

.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px 8px 8px;
  background:rgba(255,107,31,.14);
  border:1px solid rgba(255,107,31,.3);
  border-radius:var(--r-pill);
  font-size:.875rem;font-weight:600;
  color:#FFB082;
  margin-bottom:24px;
}
.hero-eyebrow .dot{
  display:inline-grid;place-items:center;width:24px;height:24px;
  background:var(--orange);border-radius:50%;color:#fff;font-size:.7rem;
}
.hero h1{color:#fff;margin-bottom:24px}
.hero h1 .accent{color:var(--orange);position:relative;display:inline-block}
.hero h1 .accent::after{
  content:"";position:absolute;left:0;right:0;bottom:8px;height:14px;
  background:var(--orange);opacity:.18;z-index:-1;border-radius:4px;
}
.hero p.lead{color:rgba(255,255,255,.78);max-width:560px;font-size:1.15rem;margin-bottom:36px}
.hero-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:48px}

.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:560px}
.hero-stat .n{font-family:var(--f-display);font-weight:800;font-size:clamp(1.75rem,3vw,2.5rem);color:#fff;line-height:1}
.hero-stat .n .plus{color:var(--orange)}
.hero-stat .l{font-size:.875rem;color:rgba(255,255,255,.6);margin-top:6px}

.hero-visual{position:relative}
.hero-card{
  position:relative;
  background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-xl);
  padding:32px;
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
}
.hero-card-image{
  border-radius:var(--r-lg);
  background:linear-gradient(135deg,#1B2541,#27314D);
  aspect-ratio:4/5;
  position:relative;overflow:hidden;
  display:grid;place-items:center;
}
.hero-card-image svg{width:60%;color:rgba(255,107,31,.6)}
.hero-floating{
  position:absolute;
  background:#fff;color:var(--text);
  padding:14px 18px;border-radius:var(--r-md);
  box-shadow:var(--shadow-3);
  display:flex;align-items:center;gap:12px;
  font-size:.875rem;font-weight:600;
}
.hero-floating .ico{
  display:grid;place-items:center;width:38px;height:38px;
  background:var(--orange-light);color:var(--orange);
  border-radius:var(--r-sm);
}
.hero-floating .ico svg{width:18px;height:18px}
.hero-float-1{top:30px;left:-20px;animation:floatY 4s var(--ease) infinite alternate}
.hero-float-2{bottom:30px;right:-20px;animation:floatY 5s var(--ease) infinite alternate-reverse}
@keyframes floatY{from{transform:translateY(0)}to{transform:translateY(-12px)}}

/* Page banner (inner pages) */
.banner{
  position:relative;
  background:var(--ink);
  color:#fff;
  padding:clamp(80px,10vw,140px) 0 clamp(60px,8vw,100px);
  overflow:hidden;
}
.banner-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 75% 30%, rgba(255,107,31,.18), transparent 55%),
    linear-gradient(135deg,#0A0E1A 0%,#10172A 70%,#1B2541 100%);
}
.banner-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:linear-gradient(180deg,black,transparent);
  -webkit-mask-image:linear-gradient(180deg,black,transparent);
}
.banner-inner{position:relative;z-index:2}
.banner h1{color:#fff;margin-bottom:14px}
.crumbs{display:flex;align-items:center;gap:10px;font-size:.9375rem;color:rgba(255,255,255,.65)}
.crumbs a:hover{color:var(--orange)}
.crumbs svg{width:14px;height:14px}
.crumbs .current{color:var(--orange)}

/* -----------------------------
   Trust strip
----------------------------- */
.trust{
  background:var(--paper-2);
  padding:32px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.trust-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.trust-item{
  display:flex;align-items:center;gap:14px;
}
.trust-item .ico{
  display:grid;place-items:center;width:48px;height:48px;
  background:#fff;color:var(--orange);
  border:1px solid var(--line);border-radius:var(--r-md);
  flex-shrink:0;
}
.trust-item .ico svg{width:22px;height:22px}
.trust-item .t{font-family:var(--f-display);font-weight:700;font-size:.9375rem;color:var(--text);line-height:1.3}
.trust-item .s{font-size:.8125rem;color:var(--text-2);margin-top:2px}

/* -----------------------------
   Service cards
----------------------------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc-card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:32px 28px;
  transition:all var(--t) var(--ease);
  overflow:hidden;
  display:flex;flex-direction:column;
}
.svc-card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,var(--ink),var(--ink-2));
  opacity:0;transition:opacity var(--t) var(--ease);z-index:0;
}
.svc-card>*{position:relative;z-index:1}
.svc-card .ico{
  display:grid;place-items:center;width:64px;height:64px;
  background:var(--orange-light);color:var(--orange);
  border-radius:var(--r-md);
  margin-bottom:24px;
  transition:all var(--t) var(--ease);
}
.svc-card .ico svg{width:30px;height:30px}
.svc-card .num{
  position:absolute;top:24px;right:28px;z-index:2;
  font-family:var(--f-display);font-weight:800;font-size:3rem;
  color:var(--paper-3);
  line-height:1;letter-spacing:-.04em;
  transition:color var(--t) var(--ease);
}
.svc-card h3{margin-bottom:12px;transition:color var(--t) var(--ease)}
.svc-card p{margin-bottom:24px;flex:1}
.svc-card .more{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-display);font-weight:600;font-size:.9375rem;
  color:var(--text);
  transition:color var(--t) var(--ease);
}
.svc-card .more svg{width:18px;height:18px;transition:transform var(--t-fast) var(--ease)}
.svc-card:hover{transform:translateY(-6px);border-color:transparent}
.svc-card:hover::before{opacity:1}
.svc-card:hover .ico{background:var(--orange);color:#fff}
.svc-card:hover .num{color:rgba(255,255,255,.06)}
.svc-card:hover h3{color:#fff}
.svc-card:hover p{color:rgba(255,255,255,.7)}
.svc-card:hover .more{color:var(--orange)}
.svc-card:hover .more svg{transform:translateX(4px)}

/* -----------------------------
   About block
----------------------------- */
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.about-visual{position:relative}
.about-img{
  aspect-ratio:4/5;border-radius:var(--r-xl);
  background:linear-gradient(135deg,#1B2541,#27314D);
  position:relative;overflow:hidden;
  display:grid;place-items:center;
}
.about-img svg{width:50%;color:rgba(255,107,31,.45)}
.about-badge{
  position:absolute;top:-30px;right:-30px;
  width:180px;height:180px;
  background:var(--orange);color:#fff;
  border-radius:50%;
  display:grid;place-items:center;
  text-align:center;
  box-shadow:var(--shadow-orange);
  border:8px solid #fff;
}
.about-badge .n{font-family:var(--f-display);font-weight:800;font-size:3rem;line-height:1}
.about-badge .l{font-size:.8125rem;font-weight:600;margin-top:4px}

.about-content h2{margin-bottom:20px}
.about-content .lead{margin-bottom:32px}
.about-points{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:36px}
.about-point{display:flex;gap:14px}
.about-point .ico{
  flex-shrink:0;
  display:grid;place-items:center;width:46px;height:46px;
  background:var(--orange-light);color:var(--orange);
  border-radius:var(--r-md);
}
.about-point .ico svg{width:22px;height:22px}
.about-point h5{font-family:var(--f-display);font-weight:700;margin-bottom:4px;font-size:1rem}
.about-point p{font-size:.875rem;line-height:1.6}

.signature{
  display:flex;align-items:center;gap:18px;padding-top:24px;border-top:1px solid var(--line);
}
.signature-avatar{
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--orange),var(--orange-dark));
  display:grid;place-items:center;color:#fff;
  font-family:var(--f-display);font-weight:700;
}
.signature-info .n{font-family:var(--f-display);font-weight:700;font-size:1rem}
.signature-info .r{font-size:.875rem;color:var(--text-2)}

/* -----------------------------
   Why choose us (orange section)
----------------------------- */
.wcu{
  background:linear-gradient(135deg,var(--orange) 0%,var(--orange-dark) 100%);
  color:#fff;position:relative;overflow:hidden;
}
.wcu::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:50px 50px;
}
.wcu-inner{position:relative;z-index:1}
.wcu .eyebrow{color:rgba(255,255,255,.95)}
.wcu .eyebrow::before{background:#fff}
.wcu h2{color:#fff}
.wcu .section-subtitle{color:rgba(255,255,255,.85)}

.wcu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px}
.wcu-card{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(12px);
  border-radius:var(--r-lg);
  padding:28px 24px;
  transition:all var(--t) var(--ease);
}
.wcu-card:hover{background:#fff;color:var(--text);transform:translateY(-4px)}
.wcu-card:hover h4{color:var(--text)}
.wcu-card:hover .ico{background:var(--orange);color:#fff}
.wcu-card .ico{
  display:grid;place-items:center;width:56px;height:56px;
  background:#fff;color:var(--orange);
  border-radius:var(--r-md);margin-bottom:20px;
  transition:all var(--t) var(--ease);
}
.wcu-card .ico svg{width:26px;height:26px}
.wcu-card h4{color:#fff;font-size:1.125rem;margin-bottom:10px;transition:color var(--t) var(--ease)}
.wcu-card p{color:rgba(255,255,255,.78);font-size:.9375rem;transition:color var(--t) var(--ease)}
.wcu-card:hover p{color:var(--text-2)}

/* -----------------------------
   Projects gallery
----------------------------- */
.proj-filter{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:48px}
.proj-filter button{
  padding:10px 22px;border-radius:var(--r-pill);
  background:var(--paper-2);
  font-family:var(--f-display);font-weight:600;font-size:.875rem;
  color:var(--text);
  transition:all var(--t-fast) var(--ease);
}
.proj-filter button:hover,.proj-filter button.active{background:var(--ink);color:#fff}

.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.proj-card{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(135deg,#1B2541,#27314D);
  aspect-ratio:4/5;
  cursor:pointer;
  display:block;
}
.proj-card-img{position:absolute;inset:0;display:grid;place-items:center}
.proj-card-img svg{width:50%;color:rgba(255,107,31,.4);transition:transform var(--t-slow) var(--ease)}
.proj-card:hover .proj-card-img svg{transform:scale(1.08)}
.proj-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 0%,transparent 40%,rgba(10,14,26,.95) 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px;color:#fff;
}
.proj-tag{
  display:inline-block;padding:4px 12px;border-radius:var(--r-pill);
  background:var(--orange);color:#fff;
  font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;
  margin-bottom:12px;align-self:flex-start;
}
.proj-card h4{color:#fff;margin-bottom:6px;font-size:1.25rem}
.proj-card .pmeta{font-size:.875rem;color:rgba(255,255,255,.7)}
.proj-card .plus{
  position:absolute;top:20px;right:20px;
  width:44px;height:44px;border-radius:50%;
  background:var(--orange);color:#fff;
  display:grid;place-items:center;
  opacity:0;transform:scale(.8);
  transition:all var(--t) var(--ease);
}
.proj-card .plus svg{width:20px;height:20px}
.proj-card:hover .plus{opacity:1;transform:scale(1)}

/* -----------------------------
   Process timeline
----------------------------- */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.process-grid::before{
  content:"";position:absolute;top:32px;left:8%;right:8%;height:2px;
  background:repeating-linear-gradient(90deg,var(--orange) 0 8px,transparent 8px 16px);
  z-index:0;
}
.process-step{position:relative;text-align:center}
.process-step .n{
  display:grid;place-items:center;width:64px;height:64px;
  margin:0 auto 20px;
  background:#fff;color:var(--orange);
  border:2px solid var(--orange);border-radius:50%;
  font-family:var(--f-display);font-weight:800;font-size:1.25rem;
  position:relative;z-index:1;
  box-shadow:0 0 0 8px rgba(255,107,31,.08);
  transition:all var(--t) var(--ease);
}
.process-step:hover .n{background:var(--orange);color:#fff;transform:scale(1.05)}
.process-step h4{margin-bottom:8px;font-size:1.125rem}
.process-step p{font-size:.9375rem}

/* -----------------------------
   Testimonials
----------------------------- */
.testi-section{background:var(--paper-2)}
.testi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.testi-card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);padding:32px;
  position:relative;
  transition:all var(--t) var(--ease);
}
.testi-card:hover{box-shadow:var(--shadow-3);transform:translateY(-4px)}
.testi-quote{
  position:absolute;top:24px;right:24px;
  color:var(--orange-light);
}
.testi-quote svg{width:48px;height:48px}
.testi-stars{display:flex;gap:4px;margin-bottom:18px}
.testi-stars svg{width:18px;height:18px;color:#FFB400;fill:#FFB400}
.testi-text{font-size:1rem;line-height:1.7;color:var(--text);margin-bottom:24px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:14px}
.testi-avatar{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--orange),var(--orange-dark));
  display:grid;place-items:center;color:#fff;font-family:var(--f-display);font-weight:700;
}
.testi-name{font-family:var(--f-display);font-weight:700}
.testi-role{font-size:.875rem;color:var(--text-2)}

/* -----------------------------
   Team
----------------------------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.team-card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);
  overflow:hidden;text-align:center;
  transition:all var(--t) var(--ease);
}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-3);border-color:transparent}
.team-photo{
  aspect-ratio:1/1;
  background:linear-gradient(135deg,#1B2541,#27314D);
  display:grid;place-items:center;
  position:relative;overflow:hidden;
}
.team-photo .initials{font-family:var(--f-display);font-weight:800;font-size:3rem;color:rgba(255,107,31,.6)}
.team-social{
  position:absolute;bottom:14px;left:50%;transform:translate(-50%,20px);
  display:flex;gap:8px;
  opacity:0;transition:all var(--t) var(--ease);
}
.team-card:hover .team-social{opacity:1;transform:translate(-50%,0)}
.team-social a{
  display:grid;place-items:center;width:34px;height:34px;border-radius:50%;
  background:#fff;color:var(--text);
  transition:all var(--t-fast) var(--ease);
}
.team-social a:hover{background:var(--orange);color:#fff}
.team-social svg{width:15px;height:15px}
.team-info{padding:24px 20px}
.team-info h4{margin-bottom:4px;font-size:1.0625rem}
.team-info .role{color:var(--orange);font-size:.875rem;font-weight:600}

/* -----------------------------
   Blog cards
----------------------------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;
  transition:all var(--t) var(--ease);
  display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-3);border-color:transparent}
.blog-img{
  aspect-ratio:16/10;
  background:linear-gradient(135deg,#1B2541,#27314D);
  display:grid;place-items:center;position:relative;overflow:hidden;
}
.blog-img svg{width:40%;color:rgba(255,107,31,.5)}
.blog-date{
  position:absolute;top:14px;left:14px;
  background:var(--orange);color:#fff;
  padding:8px 12px;border-radius:var(--r-md);
  text-align:center;
}
.blog-date .d{font-family:var(--f-display);font-weight:800;font-size:1.25rem;line-height:1}
.blog-date .m{font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;margin-top:2px}
.blog-body{padding:28px;flex:1;display:flex;flex-direction:column}
.blog-meta{display:flex;align-items:center;gap:16px;font-size:.8125rem;color:var(--text-2);margin-bottom:14px}
.blog-meta span{display:inline-flex;align-items:center;gap:6px}
.blog-meta svg{width:14px;height:14px;color:var(--orange)}
.blog-card h3{font-size:1.25rem;margin-bottom:14px;line-height:1.35}
.blog-card h3 a:hover{color:var(--orange)}
.blog-card p{font-size:.9375rem;margin-bottom:20px;flex:1}
.blog-card .more{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-display);font-weight:600;font-size:.875rem;color:var(--orange);
}
.blog-card .more svg{width:16px;height:16px;transition:transform var(--t-fast) var(--ease)}
.blog-card:hover .more svg{transform:translateX(4px)}

/* -----------------------------
   CTA banner
----------------------------- */
.cta{
  background:linear-gradient(135deg,var(--ink) 0%,var(--ink-3) 100%);
  color:#fff;position:relative;overflow:hidden;
  border-radius:var(--r-xl);
  padding:64px clamp(32px,5vw,72px);
}
.cta::before{
  content:"";position:absolute;top:-50%;right:-10%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(255,107,31,.25),transparent 60%);
  pointer-events:none;
}
.cta-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;position:relative;z-index:1}
.cta h2{color:#fff;margin-bottom:14px}
.cta p{color:rgba(255,255,255,.78);font-size:1.0625rem}
.cta-actions{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.cta-actions .phone{
  display:inline-flex;align-items:center;gap:14px;color:#fff;
}
.cta-actions .phone .ico{
  display:grid;place-items:center;width:56px;height:56px;
  background:var(--orange);border-radius:var(--r-md);
}
.cta-actions .phone .ico svg{width:24px;height:24px;color:#fff}
.cta-actions .phone .l{font-size:.875rem;color:rgba(255,255,255,.65)}
.cta-actions .phone .n{font-family:var(--f-display);font-weight:800;font-size:1.5rem}

/* -----------------------------
   Form
----------------------------- */
.form-card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-xl);padding:clamp(28px,4vw,48px);
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-field{position:relative}
.form-field.full{grid-column:1/-1}
.form-field label{
  display:block;font-family:var(--f-display);font-weight:600;
  font-size:.875rem;margin-bottom:8px;color:var(--text);
}
.form-field input,.form-field select,.form-field textarea{
  width:100%;padding:14px 16px;
  background:var(--paper-2);
  border:1.5px solid transparent;
  border-radius:var(--r-md);
  font-size:.9375rem;color:var(--text);
  transition:all var(--t-fast) var(--ease);
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--orange);background:#fff;
  box-shadow:0 0 0 4px rgba(255,107,31,.1);
}
.form-field textarea{min-height:140px;resize:vertical;font-family:var(--f-body)}

/* Contact info card */
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:48px}
.contact-card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);padding:32px;
  display:flex;gap:18px;align-items:flex-start;
  transition:all var(--t) var(--ease);
}
.contact-card:hover{border-color:var(--orange);transform:translateY(-4px);box-shadow:var(--shadow-2)}
.contact-card .ico{
  flex-shrink:0;display:grid;place-items:center;width:54px;height:54px;
  background:var(--orange-light);color:var(--orange);
  border-radius:var(--r-md);
}
.contact-card .ico svg{width:24px;height:24px}
.contact-card h5{font-family:var(--f-display);font-weight:700;margin-bottom:6px;font-size:1rem}
.contact-card p{font-size:.9375rem;line-height:1.55}
.contact-card a:hover{color:var(--orange)}

/* -----------------------------
   Footer
----------------------------- */
.footer{background:var(--ink);color:rgba(255,255,255,.7);padding-top:80px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;padding-bottom:64px}
.footer-brand img{height:64px;margin-bottom:20px}
.footer-brand p{color:rgba(255,255,255,.65);font-size:.9375rem;margin-bottom:24px;max-width:340px}
.footer-social{display:flex;gap:10px}
.footer-social a{
  display:grid;place-items:center;width:38px;height:38px;border-radius:var(--r-sm);
  background:rgba(255,255,255,.06);color:rgba(255,255,255,.75);
  transition:all var(--t-fast) var(--ease);
}
.footer-social a:hover{background:var(--orange);color:#fff;transform:translateY(-2px)}
.footer-social svg{width:16px;height:16px}

.footer h5{
  color:#fff;font-family:var(--f-display);font-weight:700;
  font-size:1.0625rem;margin-bottom:22px;position:relative;padding-bottom:14px;
}
.footer h5::after{content:"";position:absolute;left:0;bottom:0;width:36px;height:2px;background:var(--orange)}
.footer ul li{margin-bottom:10px}
.footer ul a{font-size:.9375rem;display:inline-flex;align-items:center;gap:8px}
.footer ul a:hover{color:var(--orange);transform:translateX(4px)}
.footer ul a svg{width:14px;height:14px;color:var(--orange)}
.footer-contact li{display:flex;gap:12px;margin-bottom:14px;font-size:.9375rem}
.footer-contact .ico{
  flex-shrink:0;display:grid;place-items:center;width:32px;height:32px;
  background:rgba(255,107,31,.14);color:var(--orange);border-radius:var(--r-sm);
}
.footer-contact .ico svg{width:14px;height:14px}

.newsletter{display:flex;gap:8px;margin-top:8px}
.newsletter input{
  flex:1;padding:12px 14px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);
  color:#fff;font-size:.875rem;
}
.newsletter input::placeholder{color:rgba(255,255,255,.5)}
.newsletter input:focus{outline:none;border-color:var(--orange);background:rgba(255,255,255,.1)}
.newsletter button{
  padding:12px 16px;background:var(--orange);color:#fff;
  border-radius:var(--r-md);font-weight:600;
  transition:all var(--t-fast) var(--ease);
}
.newsletter button:hover{background:var(--orange-dark)}
.newsletter button svg{width:18px;height:18px}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding:24px 0;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-size:.875rem;
}
.footer-bottom a:hover{color:var(--orange)}
.footer-bottom-links{display:flex;gap:24px}

/* -----------------------------
   Back to top
----------------------------- */
.to-top{
  position:fixed;bottom:28px;right:28px;z-index:80;
  width:48px;height:48px;border-radius:50%;
  background:var(--orange);color:#fff;
  display:grid;place-items:center;
  box-shadow:var(--shadow-orange);
  opacity:0;transform:translateY(20px);pointer-events:none;
  transition:all var(--t) var(--ease);
}
.to-top.show{opacity:1;transform:translateY(0);pointer-events:auto}
.to-top:hover{background:var(--orange-dark);transform:translateY(-4px)}
.to-top svg{width:20px;height:20px}

/* -----------------------------
   Service detail
----------------------------- */
.svc-detail{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:flex-start}
.svc-detail-main h2{margin-top:32px;margin-bottom:16px}
.svc-detail-main h3{margin-top:28px;margin-bottom:12px;font-size:1.5rem}
.svc-detail-main p{margin-bottom:18px;font-size:1.0625rem;line-height:1.75;color:var(--text-2)}
.svc-hero-img{
  border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:16/9;
  background:linear-gradient(135deg,#1B2541,#27314D);
  display:grid;place-items:center;margin-bottom:32px;
}
.svc-hero-img svg{width:30%;color:rgba(255,107,31,.5)}

.svc-features{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
  margin:28px 0;
}
.svc-features li{
  display:flex;align-items:center;gap:12px;
  padding:16px;background:var(--paper-2);
  border-radius:var(--r-md);
  font-weight:500;color:var(--text);
}
.svc-features li .ico{
  display:grid;place-items:center;width:28px;height:28px;
  background:var(--orange);color:#fff;border-radius:50%;flex-shrink:0;
}
.svc-features li .ico svg{width:14px;height:14px}

/* Sidebar */
.sidebar-card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);padding:28px;margin-bottom:24px;
}
.sidebar-card h5{
  font-family:var(--f-display);font-weight:700;font-size:1.0625rem;
  margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--line);
  position:relative;
}
.sidebar-card h5::after{content:"";position:absolute;left:0;bottom:-1px;width:36px;height:2px;background:var(--orange)}
.sb-cat li a{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border-radius:var(--r-md);
  background:var(--paper-2);font-weight:500;
  transition:all var(--t-fast) var(--ease);
  margin-bottom:8px;
}
.sb-cat li a:hover{background:var(--orange);color:#fff}
.sb-cat li a.active{background:var(--ink);color:#fff}
.sb-cat li a .badge{
  display:grid;place-items:center;min-width:28px;height:28px;padding:0 8px;
  background:#fff;color:var(--orange);border-radius:var(--r-sm);
  font-size:.8125rem;font-weight:700;
}
.sb-cat li a:hover .badge,.sb-cat li a.active .badge{background:var(--orange);color:#fff}

.sb-cta{
  background:linear-gradient(135deg,var(--ink),var(--ink-3));
  color:#fff;border:0;
  position:relative;overflow:hidden;
}
.sb-cta::before{
  content:"";position:absolute;top:-50%;right:-30%;width:300px;height:300px;
  background:radial-gradient(circle,rgba(255,107,31,.3),transparent 60%);
}
.sb-cta>*{position:relative;z-index:1}
.sb-cta h5{color:#fff;border-color:rgba(255,255,255,.12)}
.sb-cta .phone-big{font-family:var(--f-display);font-weight:800;font-size:1.5rem;margin:14px 0}
.sb-cta p{color:rgba(255,255,255,.75);font-size:.9375rem;margin-bottom:18px}

.dl-row{
  display:flex;align-items:center;gap:14px;
  padding:14px;background:var(--paper-2);
  border-radius:var(--r-md);margin-bottom:10px;
  transition:all var(--t-fast) var(--ease);
}
.dl-row:hover{background:var(--orange);color:#fff}
.dl-row:hover .dl-ico,.dl-row:hover .dl-arrow{background:#fff;color:var(--orange)}
.dl-row:hover .dl-sub{color:rgba(255,255,255,.85)}
.dl-ico{
  display:grid;place-items:center;width:42px;height:42px;
  background:var(--orange);color:#fff;border-radius:var(--r-sm);flex-shrink:0;
  transition:all var(--t-fast) var(--ease);
}
.dl-ico svg{width:18px;height:18px}
.dl-text{flex:1}
.dl-title{font-family:var(--f-display);font-weight:700;font-size:.9375rem}
.dl-sub{font-size:.8125rem;color:var(--text-2);transition:color var(--t-fast) var(--ease)}
.dl-arrow{
  display:grid;place-items:center;width:32px;height:32px;
  background:#fff;color:var(--text);border-radius:var(--r-sm);
  transition:all var(--t-fast) var(--ease);
}
.dl-arrow svg{width:14px;height:14px}

/* Process small */
.process-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.process-mini-card{
  text-align:center;padding:28px 20px;
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);
  position:relative;
}
.process-mini-card .ico{
  display:grid;place-items:center;width:64px;height:64px;
  margin:0 auto 16px;
  background:var(--orange);color:#fff;border-radius:50%;
  box-shadow:0 0 0 8px rgba(255,107,31,.1);
}
.process-mini-card .ico svg{width:28px;height:28px}
.process-mini-card h5{font-family:var(--f-display);font-weight:700;font-size:1.0625rem;margin-bottom:8px}
.process-mini-card p{font-size:.875rem;line-height:1.6}

/* Project detail info */
.proj-info-card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);padding:32px;
}
.proj-info-card h4{padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:20px;position:relative}
.proj-info-card h4::after{content:"";position:absolute;left:0;bottom:-1px;width:48px;height:2px;background:var(--orange)}
.proj-info-list li{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px dashed var(--line);font-size:.9375rem}
.proj-info-list li:last-child{border-bottom:0}
.proj-info-list .label{color:var(--text-2);font-weight:500}
.proj-info-list .val{color:var(--text);font-family:var(--f-display);font-weight:600}

/* -----------------------------
   Animations
----------------------------- */
.fade-up{opacity:0;transform:translateY(24px);transition:all var(--t-slow) var(--ease-out)}
.fade-up.in{opacity:1;transform:translateY(0)}
.fade-in{opacity:0;transition:opacity var(--t-slow) var(--ease-out)}
.fade-in.in{opacity:1}
.scale-in{opacity:0;transform:scale(.95);transition:all var(--t-slow) var(--ease-out)}
.scale-in.in{opacity:1;transform:scale(1)}

@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}

/* -----------------------------
   Responsive
----------------------------- */
@media (max-width:1100px){
  .hero-inner{grid-template-columns:1fr;gap:48px}
  .hero-visual{max-width:480px;margin:0 auto}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .about-badge{width:140px;height:140px;top:-20px;right:20px}
  .about-badge .n{font-size:2.25rem}
  .svc-grid,.proj-grid,.blog-grid,.process-grid,.team-grid,.contact-cards{grid-template-columns:repeat(2,1fr)}
  .wcu-grid{grid-template-columns:repeat(2,1fr)}
  .trust-inner{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:1fr}
  .svc-detail{grid-template-columns:1fr}
  .cta-inner{grid-template-columns:1fr;text-align:center}
  .cta-actions{align-items:center}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .nav,.header-cta .btn{display:none}
  .burger{display:grid}
  .process-grid::before{display:none}
}
@media (max-width:680px){
  :root{--header-h:72px}
  .topbar-inner{height:auto;padding:10px 0;justify-content:center;text-align:center}
  .topbar-left{justify-content:center;gap:14px}
  .topbar-item{font-size:.8125rem}
  .brand img{height:48px}
  .hero-stats{grid-template-columns:1fr;gap:16px;max-width:none}
  .hero-stat{display:flex;align-items:baseline;gap:14px}
  .hero-stat .l{margin-top:0}
  .svc-grid,.proj-grid,.blog-grid,.process-grid,.team-grid,.contact-cards{grid-template-columns:1fr}
  .wcu-grid{grid-template-columns:1fr}
  .about-points,.form-grid,.svc-features,.process-mini{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .proj-filter{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px}
  .proj-filter button{flex-shrink:0}
  .header-inner{height:var(--header-h-sm,72px)}
  .about-badge{position:static;width:auto;height:auto;border-radius:var(--r-lg);padding:20px;margin-top:-40px;margin-left:24px;display:inline-grid}
  .topbar-social{display:none}
}
