:root{
  --navy:#133b69;
  --navy-2:#0d2d50;
  --navy-3:#091b31;
  --orange:#f36a10;
  --orange-soft:#ff8a3d;
  --text:#eef3f9;
  --muted:#bcc7d4;
  --line:rgba(255,255,255,.08);
  --shadow:0 28px 80px rgba(0,0,0,.36);
  --panel:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  --max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(243,106,16,.08), transparent 24%),
    radial-gradient(circle at top right, rgba(19,59,105,.22), transparent 28%),
    linear-gradient(180deg, #07111e 0%, #08131f 42%, #07111b 100%);
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.grain{
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.07;
  background-image:radial-gradient(rgba(255,255,255,.30) 0.5px, transparent 0.7px);
  background-size:7px 7px;
  mix-blend-mode:soft-light;
  z-index:0;
}
.container{width:min(var(--max), calc(100% - 36px));margin:0 auto}
.site-header,.hero,.section,.ribbon,.site-footer{position:relative;z-index:1}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(16px);
  background:rgba(6,13,23,.72);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav{
  min-height:88px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.brand img{width:220px;height:auto}
.nav-links{display:flex;gap:28px}
.nav-links a{
  color:var(--muted);
  font-weight:700;
  position:relative;
}
.nav-links a::after{
  content:"";
  position:absolute;
  left:0;bottom:-10px;
  width:0;height:2px;
  background:linear-gradient(90deg, var(--orange), transparent);
  transition:width .22s ease;
}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:12px}
.nav-phone{
  border:1px solid rgba(255,255,255,.10);
  padding:12px 16px;
  border-radius:999px;
  font-weight:800;
  white-space:nowrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 22px;
  border-radius:999px;
  font-weight:800;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  position:relative;
  overflow:hidden;
}
.btn:hover{transform:translateY(-2px)}
.btn::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 20%, rgba(255,255,255,.14) 50%, transparent 80%);
  transform:translateX(-130%);
  transition:transform .55s ease;
}
.btn:hover::after{transform:translateX(130%)}
.btn-orange{
  background:linear-gradient(180deg, var(--orange-soft), var(--orange));
  color:white;
  box-shadow:0 16px 32px rgba(243,106,16,.22);
}
.btn-outline{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.02);
  color:var(--text);
}
.btn-lg{padding:16px 26px}
.btn-full{width:100%}

.hero{
  padding:84px 0 44px;
  overflow:hidden;
}
.hero-left-glow,.hero-right-glow{
  position:absolute;
  border-radius:50%;
  filter:blur(20px);
  pointer-events:none;
}
.hero-left-glow{
  left:-12%;
  top:18%;
  width:34vw;height:34vw;
  background:radial-gradient(circle, rgba(243,106,16,.10), transparent 68%);
}
.hero-right-glow{
  right:-8%;
  top:10%;
  width:30vw;height:30vw;
  background:radial-gradient(circle, rgba(19,59,105,.28), transparent 62%);
}
.hero-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:42px;
  align-items:start;
}
.eyebrow,.section-label{
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.8rem;
  color:var(--orange-soft);
  font-weight:900;
}
.section-label::after{
  content:"";
  display:block;
  width:68px;height:2px;
  margin-top:10px;
  background:linear-gradient(90deg, var(--orange), transparent);
}
.hero h1,
.section h2{
  font-family:'Plus Jakarta Sans','Inter',sans-serif;
  line-height:.95;
  letter-spacing:-.05em;
  margin:.18em 0 .28em;
}
.hero h1{
  font-size:clamp(3.25rem, 7vw, 5.8rem);
  max-width:10ch;
}
.hero-text{
  max-width:650px;
  color:var(--muted);
  font-size:1.06rem;
  line-height:1.9;
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin:28px 0 22px;
}
.workflow-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin-top:22px;
}
.workflow-strip span{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  border-radius:18px;
  padding:14px 14px;
  font-weight:800;
  color:#dce6f2;
  text-align:center;
  font-size:.94rem;
}
.hero-panel{
  position:relative;
  min-height:620px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015)),
    linear-gradient(135deg, rgba(19,59,105,.16), transparent 38%),
    radial-gradient(circle at 78% 18%, rgba(243,106,16,.12), transparent 30%);
  box-shadow:
    0 34px 90px rgba(0,0,0,.44),
    inset 0 -28px 60px rgba(0,0,0,.14);
  display:grid;
  place-items:center;
  padding:42px;
  overflow:hidden;
}
.hero-main-logo{
  width:min(580px, 94%);
  filter:drop-shadow(0 20px 45px rgba(0,0,0,.52));
  position:relative;
  z-index:2;
}
.hero-spec{
  position:absolute;
  top:24px;
  left:24px;
  right:24px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  z-index:2;
}
.hero-spec div{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(6,13,23,.36);
  border-radius:14px;
  padding:14px 16px;
}
.hero-spec strong{
  display:block;
  color:#fff;
  font-size:.84rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:6px;
}
.hero-spec span{
  color:var(--muted);
  font-size:.92rem;
}
.panel-shimmer{
  position:absolute;
  inset:-8% auto -8% -35%;
  width:34%;
  background:linear-gradient(115deg, transparent 0%, rgba(255,255,255,.02) 35%, rgba(255,138,61,.16) 50%, rgba(255,255,255,.03) 65%, transparent 100%);
  transform:skewX(-18deg);
  animation:sweep 8.4s ease-in-out infinite;
  filter:blur(2px);
}
@keyframes sweep{
  0%,68%,100%{left:-40%;opacity:0}
  76%{opacity:.8}
  92%{left:110%;opacity:.28}
}

.ribbon{
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
}
.ribbon-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  padding:18px 0;
}
.ribbon-grid div{
  text-align:center;
  font-weight:800;
  color:#dbe5f1;
  position:relative;
}
.ribbon-grid div:not(:last-child)::after{
  content:"";
  position:absolute;
  right:-9px;top:50%;
  transform:translateY(-50%);
  width:1px;height:20px;
  background:rgba(255,138,61,.18);
}

.section{padding:84px 0}
.section-shell{
  border:1px solid rgba(255,255,255,.07);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.012));
  box-shadow:0 22px 58px rgba(0,0,0,.18);
  padding:30px;
}
.split-shell{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:24px;
  align-items:end;
}
.section h2{
  font-size:clamp(2.35rem, 5vw, 3.9rem);
}
.intro-right p,
.services-copy,
.contact-copy{
  color:var(--muted);
  line-height:1.9;
}
.services-shell{
  display:grid;
  grid-template-columns:.78fr 1.22fr;
  gap:30px;
  align-items:start;
}
.services-left{
  position:sticky;
  top:110px;
}
.services-right{
  display:grid;
  gap:18px;
}
.service-row{
  display:grid;
  grid-template-columns:.65fr 1.35fr;
  gap:18px;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:18px;
}
.service-row:first-child{border-top:0;padding-top:0}
.service-title h3{
  margin:0;
  font-size:1.75rem;
  line-height:1.05;
}
.service-detail p{
  margin:0;
  color:var(--muted);
  line-height:1.85;
}
.service-detail ul{
  margin:14px 0 0;
  padding-left:18px;
  color:#e5edf7;
}
.service-detail li{margin:10px 0}

.why-shell{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:24px;
  align-items:center;
}
.why-copy p{
  color:var(--muted);
  line-height:1.9;
}
.check-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin-top:24px;
}
.check-item{
  padding:16px 18px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  font-weight:700;
}
.check-item::before{
  content:"✓";
  color:var(--orange-soft);
  margin-right:10px;
}
.shield-panel{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)),
    linear-gradient(135deg, rgba(19,59,105,.18), transparent 40%);
  box-shadow:var(--shadow);
  padding:34px;
  min-height:520px;
  display:grid;
  place-items:center;
}
.shield-panel img{
  width:min(350px, 82%);
  filter:drop-shadow(0 22px 48px rgba(0,0,0,.45));
}

.process-head{margin-bottom:24px}
.process-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.process-card{
  min-height:230px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:var(--panel);
  box-shadow:var(--shadow);
  padding:24px;
}
.process-card:hover{
  transform:translateY(-4px);
  border-color:rgba(243,106,16,.24);
}
.process-kicker{
  color:var(--orange-soft);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:900;
  font-size:.74rem;
  margin-bottom:12px;
}
.process-card h3{
  margin:0 0 12px;
  font-size:1.22rem;
}
.process-card p{
  color:var(--muted);
  line-height:1.8;
}

.upload-shell{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:24px;
  align-items:start;
}
.upload-copy p{
  color:var(--muted);
  line-height:1.9;
  max-width:700px;
}
.upload-points{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}
.upload-points span{
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  color:#d9e3ef;
  font-weight:700;
}
.upload-card{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)),
    radial-gradient(circle at top right, rgba(243,106,16,.12), transparent 32%);
  box-shadow:var(--shadow);
  padding:30px;
}
.upload-card h3{
  margin:0 0 18px;
  font-size:1.58rem;
}
.upload-card label{
  display:grid;
  gap:8px;
  margin:14px 0;
  font-weight:700;
  color:#edf3fa;
}
.upload-card input,
.upload-card textarea{
  width:100%;
  background:rgba(6,13,23,.52);
  color:var(--text);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:15px 16px;
  font:inherit;
}
.upload-card input:focus,
.upload-card textarea:focus{
  outline:none;
  border-color:var(--orange);
}
.file-upload small{
  color:var(--muted);
  font-weight:500;
  font-size:.86rem;
}
.file-upload input[type="file"]{
  padding:14px 16px;
  background:rgba(6,13,23,.52);
  border:1px dashed rgba(243,106,16,.38);
  border-radius:14px;
  color:var(--muted);
  cursor:pointer;
}
.file-upload input[type="file"]::file-selector-button{
  margin-right:14px;
  border:0;
  border-radius:999px;
  padding:10px 14px;
  font:inherit;
  font-weight:700;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.06));
  color:var(--text);
  cursor:pointer;
}

.contact-head{margin-bottom:20px}
.contact-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.contact-tile{
  min-height:160px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:var(--panel);
  box-shadow:var(--shadow);
  padding:24px;
  display:grid;
  align-content:start;
  gap:10px;
}
.contact-tile:hover{
  transform:translateY(-4px);
  border-color:rgba(243,106,16,.24);
}
.contact-tile strong{font-size:1rem}
.contact-tile span{
  color:var(--muted);
  line-height:1.7;
  word-break:break-word;
}

.site-footer{
  padding:26px 0 40px;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-grid{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:24px;
  align-items:center;
}
.footer-brand img{width:220px;height:auto}
.footer-copy strong{
  display:block;
  font-size:1rem;
}
.footer-copy span{
  color:var(--muted);
  font-size:.92rem;
}
.footer-links{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}
.footer-links a{
  color:var(--muted);
  font-weight:700;
}
.footer-links a:hover{color:var(--text)}

.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .8s ease, transform .8s ease;
}
.reveal-right{transform:translateX(28px)}
.reveal-up{transform:translateY(30px)}
.reveal.is-visible{
  opacity:1;
  transform:none;
}

.mobile-cta{
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  bottom:16px;
  z-index:60;
  display:none;
  padding:14px 22px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--orange-soft), var(--orange));
  color:#fff;
  font-weight:900;
  box-shadow:0 18px 34px rgba(0,0,0,.35);
}

@media (max-width: 1100px){
  .hero-grid,
  .split-shell,
  .services-shell,
  .why-shell,
  .upload-shell,
  .footer-grid{
    grid-template-columns:1fr;
  }
  .services-left{position:static}
  .service-row{
    grid-template-columns:1fr;
  }
  .services-right,
  .process-grid,
  .contact-grid{
    grid-template-columns:1fr;
  }
}
@media (max-width: 860px){
  .site-header{position:static}
  .nav{
    min-height:auto;
    padding:18px 0;
    flex-wrap:wrap;
  }
  .nav-links{display:none}
  .nav-actions{
    width:100%;
    justify-content:space-between;
  }
  .hero{padding-top:34px}
  .workflow-strip,
  .ribbon-grid,
  .check-grid,
  .hero-spec{
    grid-template-columns:1fr;
  }
  .ribbon-grid div:not(:last-child)::after{display:none}
  .shield-panel{min-height:auto}
  .mobile-cta{display:inline-flex}
}
@media (max-width: 560px){
  .brand img,.footer-brand img{width:180px}
  .nav-phone{font-size:.94rem;padding:11px 14px}
  .hero h1{font-size:3rem}
  .btn-lg{width:100%}
  .hero-actions{display:grid}
  .section-shell{padding:22px}
  .hero-panel{min-height:auto;padding:24px}
  .hero-spec{
    position:relative;
    top:auto;left:auto;right:auto;
    margin-bottom:14px;
  }
}


/* FINAL PREMIUM ROUND */
body{
  background:
    radial-gradient(circle at 8% 16%, rgba(243,106,16,.10), transparent 22%),
    radial-gradient(circle at 88% 10%, rgba(19,59,105,.26), transparent 26%),
    radial-gradient(circle at 50% 100%, rgba(255,255,255,.03), transparent 28%),
    linear-gradient(180deg, #050d19 0%, #07111e 40%, #07101a 100%);
}

.site-header{
  background:linear-gradient(180deg, rgba(5,12,22,.82), rgba(5,12,22,.72));
  box-shadow:0 10px 30px rgba(0,0,0,.16);
}

.brand img{
  width:auto;
  height:62px;
  background:transparent;
  object-fit:contain;
  filter:drop-shadow(0 6px 18px rgba(0,0,0,.32));
}

.hero{
  padding-top:92px;
}

.hero h1{
  max-width:9.4ch;
  letter-spacing:-.065em;
  text-shadow:0 10px 34px rgba(0,0,0,.22);
}

.hero-subline{
  margin:0 0 18px;
  color:#d8e4f2;
  font-weight:800;
  letter-spacing:.01em;
}

.hero-panel{
  border-radius:22px;
  border-color:rgba(255,255,255,.12);
  min-height:640px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012)),
    linear-gradient(135deg, rgba(19,59,105,.18), transparent 42%),
    radial-gradient(circle at 78% 18%, rgba(243,106,16,.11), transparent 28%);
  overflow:hidden;
}

.blueprint-grid{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size:26px 26px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.26), transparent 75%);
  pointer-events:none;
}

.corner-line{
  position:absolute;
  width:120px;
  height:120px;
  border-color:rgba(243,106,16,.22);
  pointer-events:none;
}
.corner-line-top{
  top:20px;
  right:20px;
  border-top:1px solid rgba(243,106,16,.22);
  border-right:1px solid rgba(243,106,16,.22);
}
.corner-line-bottom{
  left:20px;
  bottom:20px;
  border-left:1px solid rgba(255,255,255,.10);
  border-bottom:1px solid rgba(255,255,255,.10);
}

.hero-main-logo{
  width:min(560px, 90%);
  border-radius:6px;
  box-shadow:0 28px 70px rgba(0,0,0,.45);
}

.section-shell{
  border-radius:24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.012)),
    linear-gradient(135deg, rgba(19,59,105,.06), transparent 35%);
}

.services-shell{
  grid-template-columns:.72fr 1.28fr;
}

.service-row{
  padding:22px 0 0;
  position:relative;
}
.service-row::after{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:92px;
  height:1px;
  background:linear-gradient(90deg, rgba(243,106,16,.8), transparent);
}
.service-title h3{
  font-size:1.6rem;
}
.service-detail p{
  max-width:720px;
}

.workflow-strip span{
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}

.check-item,
.process-card,
.contact-tile,
.upload-card{
  border-radius:16px;
}

.shield-panel{
  border-radius:22px;
}

.cred-strip{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.cred-strip span{
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  color:#dbe7f3;
  font-weight:700;
}

.footer-brand img{
  width:220px;
  height:auto;
}

@media (max-width: 860px){
  .brand img{height:54px;}
  .hero-panel{min-height:auto;}
}
