/* ============================================================
   CYNINGES — Design tokens & component library
   Dark sovereign-tech system · navy / teal / forest
   Type: Sora (display) · Archivo (text) · IBM Plex Mono (tech)
   ============================================================ */

:root{
  /* color */
  --bg-0:#050b16;          /* page base */
  --bg-1:#081120;          /* deep section */
  --bg-2:#0c1830;          /* raised section */
  --panel:#0d1c33;         /* card */
  --panel-2:#112440;       /* card hover / raised */
  --line:rgba(148,184,230,.14);
  --line-strong:rgba(148,184,230,.26);
  --ink:#e9f0f9;
  --ink-2:#aebdd2;
  --ink-3:#7d8fa9;
  --teal:#00d4aa;
  --teal-soft:rgba(0,212,170,.12);
  --cyan:#3ad0f0;
  --green:#2e8b57;
  --green-soft:rgba(46,139,87,.16);
  --amber:#e8b34b;
  --red:#ff5063;
  --grad-accent:linear-gradient(92deg,var(--teal),var(--cyan));
  /* type */
  --f-display:"Sora",sans-serif;
  --f-text:"Archivo",sans-serif;
  --f-mono:"IBM Plex Mono",monospace;
  /* shape */
  --r-s:8px; --r-m:14px; --r-l:22px;
  --shadow:0 24px 60px -24px rgba(2,8,20,.8);
  --wrap:1240px;
  --header-h:76px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg-0);color:var(--ink);
  font-family:var(--f-text);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
::selection{background:rgba(0,212,170,.3);}
img,svg,canvas,video{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;}
:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:4px;}

/* ---------- typography ---------- */
h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;line-height:1.12;letter-spacing:-.015em;text-wrap:balance;}
.d1{font-size:clamp(42px,5.6vw,84px);font-weight:700;letter-spacing:-.03em;}
.d2{font-size:clamp(32px,3.6vw,52px);font-weight:700;letter-spacing:-.025em;}
.d3{font-size:clamp(24px,2.4vw,34px);}
.d4{font-size:21px;}
.lead{font-size:clamp(18px,1.6vw,21px);color:var(--ink-2);line-height:1.6;max-width:60ch;text-wrap:pretty;}
p{color:var(--ink-2);text-wrap:pretty;}
.eyebrow{
  font-family:var(--f-mono);font-size:12.5px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--teal);
  display:flex;align-items:center;gap:12px;
}
.mono{font-family:var(--f-mono);}
.dim{color:var(--ink-3);}
.accent{color:var(--teal);}

/* ---------- layout ---------- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 36px;}
.sec{padding:108px 0;}
.sec-tight{padding:72px 0;}
.sec-head{display:grid;gap:18px;max-width:780px;margin-bottom:56px;}
.sec-head.center{margin-inline:auto;text-align:center;}
.sec-head.center .eyebrow{justify-content:center;}
.band{background:var(--bg-1);}
.band-raised{background:var(--bg-2);border-block:1px solid var(--line);}
.grid{display:grid;gap:22px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
.split{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,6fr);gap:72px;align-items:start;}
@media(max-width:1040px){
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:repeat(2,1fr);}
  .split{grid-template-columns:1fr;gap:44px;}
}
@media(max-width:680px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
  .wrap{padding:0 22px;}
  .sec{padding:76px 0;}
}

/* ---------- header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:90;height:var(--header-h);
  display:flex;align-items:center;
  transition:background .35s,border-color .35s,backdrop-filter .35s;
  border-bottom:1px solid transparent;
}
.site-header.frosted{
  background:rgba(6,13,26,.78);backdrop-filter:blur(18px) saturate(1.3);
  border-bottom-color:var(--line);
}
.site-header .wrap{display:flex;align-items:center;gap:28px;width:100%;max-width:1400px;}
.brand{display:flex;align-items:center;gap:12px;flex:none;}
.brand .word{font-family:var(--f-display);font-weight:700;font-size:20px;letter-spacing:.005em;}
.brand-tag{display:block;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.42em;color:var(--teal);margin-top:12px;}
.nav{display:flex;gap:4px;margin-inline:auto;}
.nav a{
  font-size:14px;font-weight:500;color:var(--ink-2);
  padding:8px 11px;border-radius:8px;transition:color .2s,background .2s;white-space:nowrap;
}
@media(max-width:1340px){.nav a{padding:8px 9px;font-size:13.5px;}}
.nav a:hover{color:var(--ink);background:rgba(148,184,230,.08);}
.nav a[aria-current="page"]{color:var(--teal);}
.header-aux{display:flex;align-items:center;gap:16px;flex:none;}
.tls-pill{
  display:flex;align-items:center;gap:8px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:var(--ink-3);
  border:1px solid var(--line);border-radius:99px;padding:6px 12px;
}
.tls-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 8px var(--teal);animation:pulse-dot 2.6s infinite;}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.45}}
.lang{display:flex;gap:2px;font-family:var(--f-mono);font-size:11.5px;}
.lang button{padding:5px 7px;border-radius:6px;color:var(--ink-3);letter-spacing:.04em;}
.lang button[aria-pressed="true"]{color:var(--bg-0);background:var(--teal);font-weight:600;}
.lang button:hover:not([aria-pressed="true"]){color:var(--ink);}
@media(max-width:1400px){.tls-pill{display:none;}}
@media(max-width:1180px){.nav{display:none;}.header-aux .btn{display:none;}}

/* ---------- language toast ---------- */
.lang-toast{
  position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);
  z-index:200;background:rgba(8,18,32,.94);backdrop-filter:blur(14px);
  border:1px solid var(--line-strong);border-radius:99px;padding:12px 22px;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;color:var(--ink-2);
  opacity:0;pointer-events:none;transition:opacity .35s,transform .35s;box-shadow:var(--shadow);
}
.lang-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ---------- translation engine: hide gadget & banner ---------- */
#google_translate_element{display:none !important;}
.goog-te-banner-frame,.goog-te-banner-frame.skiptranslate{display:none !important;}
.goog-tooltip,.goog-tooltip:hover,#goog-gt-tt,.goog-te-balloon-frame{display:none !important;}
.goog-text-highlight{background:none !important;box-shadow:none !important;}
body{top:0 !important;position:static !important;}
.skiptranslate iframe{visibility:hidden !important;height:0 !important;}
font[style]{background:none !important;box-shadow:none !important;}

/* ---------- RTL ---------- */
[dir="rtl"] .eyebrow{flex-direction:row-reverse;}
[dir="rtl"] .nav{flex-direction:row-reverse;}
[dir="rtl"] .crumb,[dir="rtl"] .sec-head{text-align:right;}
[dir="rtl"] .link-arrow::after{content:"\2190";}
[dir="rtl"] .card .num{direction:ltr;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--f-display);font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:14px 26px;border-radius:10px;transition:transform .2s,box-shadow .2s,background .2s,border-color .2s;
  will-change:transform;
}
.btn-primary{background:var(--teal);color:#04261e;}
.btn-primary:hover{box-shadow:0 8px 30px -8px rgba(0,212,170,.55);}
.btn-ghost{border:1px solid var(--line-strong);color:var(--ink);}
.btn-ghost:hover{border-color:var(--teal);background:var(--teal-soft);}
.btn-s{padding:10px 18px;font-size:13.5px;border-radius:8px;}
.link-arrow{
  display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;color:var(--teal);
  font-family:var(--f-display);
}
.link-arrow::after{content:"→";transition:transform .2s;}
.link-arrow:hover::after{transform:translateX(4px);}

/* ---------- cards ---------- */
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-m);
  padding:30px;transition:transform .25s,border-color .25s,background .25s;
  position:relative;overflow:hidden;
}
.card:hover{border-color:var(--line-strong);background:var(--panel-2);}
.card h3,.card h4{margin-bottom:10px;}
.card p{font-size:15.5px;}
.card .num{
  font-family:var(--f-mono);font-size:13px;color:var(--teal);letter-spacing:.14em;
  display:block;margin-bottom:18px;
}
.card-tint-green{background:linear-gradient(150deg,#0d2433,#0c1f2a);}
.card-tint-blue{background:linear-gradient(150deg,#0e2040,#0c1830);}
.card-feature{padding:42px;border-radius:var(--r-l);}
.icon-chip{
  width:46px;height:46px;border-radius:12px;background:var(--teal-soft);
  display:grid;place-items:center;color:var(--teal);margin-bottom:20px;flex:none;
}
.icon-chip svg{width:22px;height:22px;}

/* ---------- metrics ---------- */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.metric .val{
  font-family:var(--f-display);font-weight:700;font-size:clamp(36px,3.6vw,54px);
  letter-spacing:-.02em;background:var(--grad-accent);
  -webkit-background-clip:text;background-clip:text;color:transparent;line-height:1.05;
}
.metric .lbl{font-size:14px;color:var(--ink-3);margin-top:8px;letter-spacing:.02em;}
@media(max-width:840px){.metrics{grid-template-columns:repeat(2,1fr);}}

/* ---------- pills & badges ---------- */
.pill{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;
  border:1px solid var(--line-strong);border-radius:99px;padding:7px 15px;color:var(--ink-2);
}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--teal);}
.badge-row{display:flex;flex-wrap:wrap;gap:12px;}
.cert{
  display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:10px;
  padding:12px 18px;background:rgba(13,28,51,.6);
  font-family:var(--f-mono);font-size:12.5px;letter-spacing:.06em;color:var(--ink-2);
}
.cert svg{width:16px;height:16px;color:var(--green);flex:none;}

/* ---------- page hero (interior pages) ---------- */
.phero{
  padding:calc(var(--header-h) + 96px) 0 84px;position:relative;overflow:hidden;
  background:
    radial-gradient(900px 420px at 82% -10%,rgba(0,212,170,.09),transparent 65%),
    radial-gradient(700px 380px at 8% 110%,rgba(58,208,240,.06),transparent 60%),
    var(--bg-1);
  border-bottom:1px solid var(--line);
}
.phero .grid-bg{
  position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(800px 500px at 70% 0%,#000 30%,transparent 75%);
          mask-image:radial-gradient(800px 500px at 70% 0%,#000 30%,transparent 75%);
}
.phero .wrap{position:relative;display:grid;gap:22px;max-width:var(--wrap);}
.phero h1{max-width:18ch;}
.crumb{font-family:var(--f-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);}
.crumb a:hover{color:var(--teal);}

/* ---------- forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.form-grid .full{grid-column:1/-1;}
@media(max-width:680px){.form-grid{grid-template-columns:1fr;}}
.field{display:grid;gap:8px;position:relative;}
.field label{font-size:13.5px;font-weight:600;color:var(--ink-2);letter-spacing:.02em;}
.field input,.field select,.field textarea{
  width:100%;background:rgba(6,13,26,.7);border:1px solid var(--line-strong);
  border-radius:10px;padding:13px 16px;color:var(--ink);font:inherit;font-size:15px;
  transition:border-color .2s,box-shadow .2s;
}
.field textarea{min-height:130px;resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,212,170,.15);
}
.field .lock{
  position:absolute;right:14px;top:40px;color:var(--teal);opacity:0;transform:scale(.6);
  transition:opacity .25s,transform .25s;pointer-events:none;
}
.field.encrypted .lock{opacity:1;transform:scale(1);}
.field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--ink-3) 50%),linear-gradient(135deg,var(--ink-3) 50%,transparent 50%);background-position:calc(100% - 20px) 55%,calc(100% - 15px) 55%;background-size:5px 5px;background-repeat:no-repeat;}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.form-note{
  display:flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:12px;
  color:var(--ink-3);letter-spacing:.04em;
}
.form-note svg{width:14px;height:14px;color:var(--teal);flex:none;}
.form-msg{display:none;border-radius:10px;padding:14px 18px;font-size:14.5px;border:1px solid;}
.form-msg.show{display:block;}
.form-msg.ok{border-color:rgba(0,212,170,.4);background:var(--teal-soft);color:#9ef0dd;}
.form-msg.limit{border-color:rgba(232,179,75,.4);background:rgba(232,179,75,.1);color:#f0d49a;}

/* ---------- footer ---------- */
.site-footer{background:var(--bg-1);border-top:1px solid var(--line);margin-top:0;}
.footer-top{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr 1.4fr;gap:40px;padding:72px 0 56px;}
.footer-top h5{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:18px;font-weight:500;}
.footer-top ul{list-style:none;display:grid;gap:10px;}
.footer-top ul a{font-size:14.5px;color:var(--ink-2);transition:color .2s;}
.footer-top ul a:hover{color:var(--teal);}
.footer-brand p{font-size:14.5px;max-width:34ch;margin-top:16px;}
.f-office{font-size:13.5px;color:var(--ink-2);line-height:1.7;}
.f-office strong{color:var(--ink);font-weight:600;display:block;margin-bottom:2px;}
.f-office + .f-office{margin-top:18px;}
.footer-bottom{
  border-top:1px solid var(--line);padding:24px 0;
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  font-size:13px;color:var(--ink-3);
}
.footer-bottom .legal{display:flex;gap:22px;}
.footer-bottom .legal a:hover{color:var(--teal);}
.footer-secline{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding:18px 0;border-top:1px solid var(--line);
  font-family:var(--f-mono);font-size:11.5px;letter-spacing:.05em;color:var(--ink-3);
}
.footer-secline .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);}
@media(max-width:1040px){.footer-top{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.footer-top{grid-template-columns:1fr;}}

/* ---------- reveal animation ---------- */
.rv{opacity:1;transform:none;}
@media(prefers-reduced-motion:no-preference){
  .rv{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
  .rv.in{opacity:1;transform:none;}
  .rv-d1{transition-delay:.08s}.rv-d2{transition-delay:.16s}.rv-d3{transition-delay:.24s}.rv-d4{transition-delay:.32s}
}

/* ---------- tilt ---------- */
.tilt{transform-style:preserve-3d;}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;}
}

/* ---------- misc components ---------- */
.rule-list{list-style:none;display:grid;}
.rule-list li{
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;
  padding:20px 0;border-bottom:1px solid var(--line);
}
.rule-list li:first-child{border-top:1px solid var(--line);}
.rule-list .k{font-family:var(--f-mono);font-size:13px;color:var(--teal);letter-spacing:.1em;padding-top:3px;min-width:42px;}
.rule-list strong{color:var(--ink);font-weight:600;font-family:var(--f-display);font-size:16.5px;display:block;margin-bottom:3px;}
.rule-list p{font-size:15px;}

.bar-row{display:grid;gap:8px;margin-bottom:22px;}
.bar-row .bar-head{display:flex;justify-content:space-between;font-size:14px;font-weight:600;}
.bar-row .bar-head .pct{font-family:var(--f-mono);color:var(--teal);font-weight:500;}
.bar-track{height:6px;border-radius:99px;background:rgba(148,184,230,.12);overflow:hidden;}
.bar-fill{height:100%;border-radius:99px;background:var(--grad-accent);width:0;transition:width 1.1s cubic-bezier(.2,.7,.2,1);}
.rv.in .bar-fill{width:var(--w);}
@media(prefers-reduced-motion:reduce){.bar-fill{width:var(--w);}}

.cta-banner{
  border:1px solid var(--line-strong);border-radius:var(--r-l);
  background:
    radial-gradient(640px 300px at 85% 120%,rgba(0,212,170,.14),transparent 70%),
    linear-gradient(150deg,#0e2040,#0a1424);
  padding:64px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;
}
.cta-banner h2{max-width:20ch;}
.cta-banner .actions{display:flex;gap:14px;flex-wrap:wrap;}

.ph-img{
  border:1px dashed var(--line-strong);border-radius:var(--r-m);
  background:repeating-linear-gradient(135deg,rgba(148,184,230,.05) 0 14px,transparent 14px 28px),var(--bg-1);
  display:grid;place-items:center;min-height:220px;color:var(--ink-3);
  font-family:var(--f-mono);font-size:12.5px;letter-spacing:.1em;text-align:center;padding:20px;
}

.azure-badge{
  display:inline-flex;align-items:center;gap:12px;border:1px solid var(--line-strong);
  border-radius:12px;padding:12px 20px;background:rgba(13,28,51,.65);backdrop-filter:blur(8px);
}
.azure-badge .az{width:24px;height:24px;flex:none;}
.azure-badge .t{display:grid;line-height:1.3;}
.azure-badge .t b{font-size:13.5px;font-weight:600;font-family:var(--f-display);}
.azure-badge .t span{font-size:11px;color:var(--ink-3);font-family:var(--f-mono);letter-spacing:.06em;}
