/* ManageMyCert design tokens & component styles. Mirrors the bundled
   Figma template; meant to be loaded directly by both the public web
   site and the portal. */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&family=Plus+Jakarta+Sans:wght@500;600;700;800&display=swap');

:root{
  /* Brand */
  --navy-900:#0E2A47;
  --navy-800:#13355A;
  --navy-700:#1A4170;
  --navy-50:#EEF3F9;
  --blue-600:#1E7BE5;
  --blue-500:#3A8BEC;
  --blue-100:#D8E8FB;
  --blue-50:#EEF5FE;

  --green-600:#2BB673;
  --green-500:#3FC987;
  --green-50:#E6F7EF;

  --amber-500:#F5A623;
  --amber-50:#FEF4E1;
  --coral-500:#EF5B5B;
  --coral-50:#FDECEC;

  /* Neutrals */
  --ink:#0F172A;
  --ink-2:#334155;
  --ink-3:#64748B;
  --ink-4:#94A3B8;
  --line:#E2E8F0;
  --line-2:#EEF2F7;
  --bg:#FFFFFF;
  --bg-soft:#F7F9FC;
  --bg-2:#FBFCFE;

  /* Type */
  --display:'Plus Jakarta Sans', ui-sans-serif, system-ui, sans-serif;
  --body:'DM Sans', ui-sans-serif, system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;

  /* Radii / shadow */
  --r-sm:8px; --r:12px; --r-lg:16px; --r-xl:22px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.06), 0 1px 1px rgba(15,23,42,.04);
  --shadow:0 4px 14px rgba(15,23,42,.07), 0 2px 4px rgba(15,23,42,.04);
  --shadow-lg:0 24px 60px rgba(15,23,42,.14), 0 8px 16px rgba(15,23,42,.06);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  font-size:15px;
  line-height:1.55;
}
h1,h2,h3,h4,h5{font-family:var(--display); letter-spacing:-.02em; margin:0; color:var(--navy-900); font-weight:700}
h1{font-size:clamp(40px, 5.4vw, 64px); line-height:1.05; letter-spacing:-.03em}
h2{font-size:clamp(28px, 3.4vw, 40px); line-height:1.1}
h3{font-size:22px; line-height:1.25}
p{margin:0}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:none; background:none; color:inherit}
input,textarea,select{font-family:inherit; font-size:14px; color:inherit}
img{max-width:100%}

.container{max-width:1240px; margin:0 auto; padding:0 28px}
.flex{display:flex} .col{display:flex; flex-direction:column}
.between{justify-content:space-between} .center{align-items:center; justify-content:center}
.aic{align-items:center} .jcb{justify-content:space-between}
.gap-2{gap:8px} .gap-3{gap:12px} .gap-4{gap:16px} .gap-5{gap:20px} .gap-6{gap:24px} .gap-8{gap:32px}
.muted{color:var(--ink-3)}
.mono{font-family:var(--mono)}
.pill{display:inline-flex; align-items:center; gap:6px; padding:5px 10px; border-radius:999px; font-size:12px; font-weight:600}

.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 18px; border-radius:10px;
  font-weight:600; font-size:14px;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
  white-space:nowrap;
  text-decoration:none;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--navy-900); color:#fff}
.btn-primary:hover{background:var(--navy-800); box-shadow:0 8px 22px rgba(14,42,71,.25)}
.btn-blue{background:var(--blue-600); color:#fff}
.btn-blue:hover{background:#1969C8; box-shadow:0 8px 22px rgba(30,123,229,.3)}
.btn-ghost{background:transparent; color:var(--navy-900); border:1px solid var(--line)}
.btn-ghost:hover{background:var(--navy-50)}
.btn-soft{background:var(--blue-50); color:var(--blue-600)}
.btn-soft:hover{background:var(--blue-100)}
.btn-danger{background:#fff; color:var(--coral-500); border:1px solid var(--coral-50)}
.btn-danger:hover{background:var(--coral-50)}
.btn-green{background:var(--green-600); color:#fff}
.btn-green:hover{background:#23a366}
.btn[disabled],.btn:disabled{opacity:.55; cursor:not-allowed; box-shadow:none}

.card{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg)}
.card-pad{padding:22px}

.input{
  width:100%; padding:11px 14px; border:1px solid var(--line);
  border-radius:10px; background:#fff;
  transition:border .15s, box-shadow .15s;
}
.input:focus{outline:none; border-color:var(--blue-500); box-shadow:0 0 0 4px var(--blue-50)}
.input.error{border-color:var(--coral-500)}

.badge-ok{background:var(--green-50); color:#1E8E5B}
.badge-warn{background:var(--amber-50); color:#9A6404}
.badge-err{background:var(--coral-50); color:#B53232}
.badge-info{background:var(--blue-50); color:var(--blue-600)}
.badge-neutral{background:var(--navy-50); color:var(--navy-900)}

/* nav */
.topnav{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line-2);
}
.topnav-inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
.brandmark{display:flex; align-items:center; gap:10px; font-family:var(--display); font-weight:800; color:var(--navy-900); font-size:18px; letter-spacing:-.01em}
.brandmark .my{color:var(--blue-600)}
.brandmark img{width:30px; height:30px; object-fit:contain}
.brandmark.white{color:#fff}
.brandmark.white .my{color:#7EB8F5}
.navlinks{display:flex; align-items:center; gap:6px}
.navlinks a{padding:8px 14px; border-radius:8px; font-weight:500; color:var(--ink-2); font-size:14px; cursor:pointer}
.navlinks a:hover{background:var(--navy-50); color:var(--navy-900)}
.navlinks a.active{color:var(--navy-900); background:var(--navy-50)}

/* hero gradient mesh */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(900px 480px at 12% -10%, rgba(30,123,229,.18), transparent 60%),
    radial-gradient(700px 420px at 95% 10%, rgba(43,182,115,.14), transparent 60%),
    linear-gradient(180deg, #FBFDFF 0%, #FFFFFF 100%);
}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr}}

/* keyframes */
@keyframes spin360{to{transform:rotate(360deg)}}
@keyframes pulseRing{0%{transform:scale(.95); opacity:.8} 80%{transform:scale(1.6); opacity:0} 100%{transform:scale(1.6); opacity:0}}
@keyframes shimmer{0%{background-position:-400px 0} 100%{background-position:400px 0}}
@keyframes floaty{0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)}}
@keyframes fadeUp{from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:translateY(0)}}
@keyframes scanline{0%{top:0} 100%{top:100%}}
@keyframes scanX{0%{left:-30%} 100%{left:100%}}

.shimmer{
  background:linear-gradient(90deg, #EEF2F7 25%, #F7F9FC 50%, #EEF2F7 75%);
  background-size:800px 100%;
  animation:shimmer 1.4s infinite linear;
  border-radius:8px;
}

/* portal layout */
.portal{display:grid; grid-template-columns:248px 1fr; min-height:100vh; background:var(--bg-soft)}
.sidebar{
  background:var(--navy-900); color:#fff;
  padding:22px 16px; position:sticky; top:0; height:100vh;
  display:flex; flex-direction:column; gap:6px;
}
.sidebar .brandmark{color:#fff}
.sidebar .brandmark .my{color:#7EB8F5}
.sb-section{font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#7C92AB; padding:14px 12px 6px}
.sb-link{
  display:flex; align-items:center; gap:11px;
  padding:10px 12px; border-radius:10px; color:#CBD8E8;
  font-size:14px; font-weight:500; cursor:pointer;
  transition:background .12s, color .12s;
}
.sb-link:hover{background:rgba(255,255,255,.06); color:#fff}
.sb-link.active{background:linear-gradient(135deg, var(--blue-600), #2C6EE0); color:#fff; box-shadow:0 6px 18px rgba(30,123,229,.35)}
.sb-link .count{margin-left:auto; font-size:11px; padding:2px 7px; border-radius:999px; background:rgba(255,255,255,.12)}

.portal-main{padding:28px 36px; max-width:1200px; width:100%}
.portal-head{display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:22px; flex-wrap:wrap; gap:14px}
.kpi-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:14px}
@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(2,1fr)} .portal{grid-template-columns:1fr} .sidebar{position:relative; height:auto}}

/* table */
.tbl{width:100%; border-collapse:separate; border-spacing:0}
.tbl thead th{
  text-align:left; font-size:11px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink-3); font-weight:600; padding:14px 16px; background:var(--bg-2); border-bottom:1px solid var(--line);
}
.tbl tbody td{padding:16px; border-bottom:1px solid var(--line-2); font-size:14px}
.tbl tbody tr{cursor:pointer; transition:background .1s}
.tbl tbody tr:hover{background:var(--bg-2)}
.tbl tbody tr:last-child td{border-bottom:none}

/* modal */
.modal-back{position:fixed; inset:0; background:rgba(15,23,42,.45); backdrop-filter:blur(4px); z-index:200; display:flex; align-items:center; justify-content:center; padding:20px; animation:fadeUp .2s}
.modal{background:#fff; border-radius:18px; max-width:520px; width:100%; max-height:90vh; overflow:hidden; box-shadow:var(--shadow-lg); display:flex; flex-direction:column}
.modal-lg{max-width:680px}
.modal-xl{max-width:880px}
.modal-body{padding:22px 24px; overflow-y:auto}

/* feature grid */
.feature-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:18px}
@media(max-width:900px){.feature-grid{grid-template-columns:1fr}}

/* doc tree */
.doc-tree{font-size:14px}
.doc-cat{margin-bottom:4px}
.doc-cat-head{display:flex; align-items:center; gap:8px; padding:8px 10px; border-radius:8px; cursor:pointer; font-weight:600; color:var(--navy-900)}
.doc-cat-head:hover{background:var(--navy-50)}
.doc-cat-head .chev{transition:transform .15s}
.doc-cat-head.open .chev{transform:rotate(90deg)}
.doc-sub{padding-left:24px; display:flex; flex-direction:column; gap:1px}
.doc-sub a{display:block; padding:7px 10px; border-radius:6px; color:var(--ink-2); font-size:13.5px; cursor:pointer}
.doc-sub a:hover{background:var(--blue-50); color:var(--blue-600)}
.doc-sub a.active{background:var(--blue-50); color:var(--blue-600); font-weight:600}

/* CA logos */
.ca-chip{display:inline-flex; align-items:center; gap:8px; padding:5px 10px; border-radius:8px; font-weight:600; font-size:12.5px; border:1px solid var(--line)}
.ca-le{background:#F5FBF8; color:#1E663A; border-color:#CDEAD9}
.ca-zerossl{background:#EFF6FF; color:#1F5BBA; border-color:#CFE0FA}
.ca-digicert{background:#FFFAF0; color:#9A4F0E; border-color:#F4E0BD}
.ca-sectigo{background:#FEF4F4; color:#A23232; border-color:#F4D2D2}
.ca-google{background:#F4F8FE; color:#2C5BB8; border-color:#D4E2F4}

/* tabs */
.tabs{display:flex; gap:2px; border-bottom:1px solid var(--line); margin-bottom:20px}
.tab{padding:12px 18px; font-size:14px; font-weight:600; color:var(--ink-3); border-bottom:2px solid transparent; margin-bottom:-1px; cursor:pointer}
.tab:hover{color:var(--navy-900)}
.tab.active{color:var(--blue-600); border-bottom-color:var(--blue-600)}

/* preloader scan */
.scanwrap{position:relative; height:6px; background:var(--blue-50); border-radius:999px; overflow:hidden}
.scanwrap::before{content:""; position:absolute; left:-30%; top:0; bottom:0; width:30%;
  background:linear-gradient(90deg, transparent, var(--blue-600), transparent); animation:scanX 1.4s infinite ease-in-out}

/* toggle */
.toggle{width:40px; height:22px; background:var(--line); border-radius:999px; position:relative; cursor:pointer; transition:background .15s; flex-shrink:0}
.toggle.on{background:var(--green-600)}
.toggle::after{content:""; width:18px; height:18px; background:#fff; border-radius:50%; position:absolute; top:2px; left:2px; transition:left .18s; box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle.on::after{left:20px}

/* placeholder image bg */
.placeholder-img{
  background:
    repeating-linear-gradient(135deg, rgba(14,42,71,.05) 0 8px, transparent 8px 16px),
    var(--navy-50);
  border:1px dashed var(--line); border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  color:var(--ink-3); font-family:var(--mono); font-size:11px; text-align:center;
}

/* fade in */
.fade-in{animation:fadeUp .35s both}

/* code blocks */
pre.code{
  background:var(--navy-900); color:#CBD8E8; padding:16px;
  border-radius:12px; font-family:var(--mono); font-size:12.5px; overflow:auto;
  line-height:1.55;
}
pre.code .k{color:#7EB8F5} pre.code .s{color:#7EE0A6} pre.code .c{color:#6B7B91}

/* blog */
.blog-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:22px}
@media(max-width:900px){.blog-grid{grid-template-columns:1fr}}
.blog-card{cursor:pointer; transition:transform .2s, box-shadow .2s}
.blog-card:hover{transform:translateY(-3px); box-shadow:var(--shadow)}
.blog-cover{aspect-ratio:16/10; border-radius:12px 12px 0 0; overflow:hidden; background:var(--navy-50)}

/* scrollbar restraint inside portal */
.portal-main::-webkit-scrollbar{width:8px; height:8px}
.portal-main::-webkit-scrollbar-thumb{background:var(--line); border-radius:4px}

/* selection */
::selection{background:var(--blue-100); color:var(--navy-900)}

/* ----- additions for full pages (auth, verify, etc.) ----- */
.auth-shell{
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  padding:32px 20px;
  background:
    radial-gradient(900px 480px at 12% -10%, rgba(30,123,229,.18), transparent 60%),
    radial-gradient(700px 420px at 95% 10%, rgba(43,182,115,.14), transparent 60%),
    linear-gradient(180deg, #FBFDFF 0%, #FFFFFF 100%);
}
.auth-card{max-width:440px; width:100%; background:#fff; border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow); padding:30px 32px 28px}
.field-label{font-size:12px; font-weight:600; color:var(--ink-2); margin-bottom:4px; display:block}
.divider-text{display:flex; align-items:center; gap:10px; color:var(--ink-4); font-size:12px; margin:14px 0}
.divider-text::before,.divider-text::after{content:""; flex:1; height:1px; background:var(--line)}
.alert-box{padding:11px 14px; border-radius:10px; font-size:13.5px; display:flex; gap:10px; align-items:flex-start}
.alert-error{background:var(--coral-50); color:#B53232; border:1px solid #F4D2D2}
.alert-info{background:var(--blue-50); color:var(--blue-600); border:1px solid #CFE0FA}
.alert-success{background:var(--green-50); color:#1E663A; border:1px solid #CDEAD9}
.alert-warn{background:var(--amber-50); color:#9A6404; border:1px solid #F4E0BD}

/* footer */
.footer{background:var(--navy-900); color:#CBD8E8; padding:64px 0 28px}
.footer h4{color:#fff; font-size:14px; font-family:var(--display); margin-bottom:14px; letter-spacing:.04em; text-transform:uppercase}
.footer a{color:#CBD8E8; font-size:14px; cursor:pointer; display:block; padding:5px 0}
.footer a:hover{color:#fff}
.footer-grid{display:grid; grid-template-columns:1.4fr repeat(4, 1fr); gap:32px}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-bottom{margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.08); display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; font-size:12.5px; color:#7C92AB}

/* loader inline (button) */
.loader-dot{
  width:14px; height:14px; border:2px solid currentColor; border-top-color:transparent;
  border-radius:50%; animation:spin360 .8s linear infinite; display:inline-block;
}

/* status dot (animated) */
.status-dot{position:relative; display:inline-flex; width:10px; height:10px}
.status-dot .ring{position:absolute; inset:0; border-radius:50%; opacity:.3}
.status-dot .core{position:relative; width:10px; height:10px; border-radius:50%}
.status-dot.ok .ring{background:var(--green-600); animation:pulseRing 2s infinite}
.status-dot.ok .core{background:var(--green-600)}
.status-dot.warn .ring{background:var(--amber-500)}
.status-dot.warn .core{background:var(--amber-500)}
.status-dot.err .ring{background:var(--coral-500)}
.status-dot.err .core{background:var(--coral-500)}
.status-dot.pending .ring{background:var(--ink-4)}
.status-dot.pending .core{background:var(--ink-4)}

/* small toast */
.toast{
  position:fixed; bottom:24px; right:24px; background:var(--navy-900); color:#fff;
  padding:12px 18px; border-radius:12px; box-shadow:var(--shadow-lg); z-index:300;
  display:flex; align-items:center; gap:10px; animation:fadeUp .25s; font-size:13.5px;
}
.toast .check{width:22px; height:22px; background:var(--green-600); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff}
.toast.error{background:#5C1F1F}
.toast.error .check{background:var(--coral-500)}
