/* ============================================================
 * Circulera Identity — design system extracted from Stitch
 * (ivory paper + sage greens + Source Serif 4 + Geist + 8px rhythm)
 * ============================================================ */

:root{
  --paper:#FAF8F4; --paper-dim:#F5F3EF; --white:#FFFFFF;
  --hairline:#E5E2DA; --hairline-soft:#EFEEEA;
  --primary:#144227; --primary-container:#2D5A3D;
  --secondary:#5A9B6F; --tertiary:#A8D5B0;
  --primary-shadow:rgba(20,66,39,.12);
  --ink:#1A1C19; --ink-soft:#414942; --muted:#6A5E4D;
  --ok:#2F6B3A; --warn:#B8741E; --err:#BA1A1A; --err-soft:#FFDAD6;
  --font-display:"Source Serif 4", Georgia, serif;
  --font-body:"Geist", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
}

*{box-sizing:border-box;}
html,body{
  margin:0;padding:0;background:var(--paper);color:var(--ink);
  font-family:var(--font-body);font-size:16px;line-height:1.5;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body{width:100%;max-width:100%;}
a{color:inherit;}
img{max-width:100%;height:auto;display:block;}

.container{max-width:1200px;margin:0 auto;padding:0 40px;}
@media (max-width:720px){ .container{padding:0 20px;} }
@media (max-width:380px){ .container{padding:0 16px;} }

/* ===================== NAV ===================== */
.navbar{padding:18px 0;border-bottom:1px solid var(--hairline-soft);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.logo{
  font-family:var(--font-display);font-weight:600;font-size:22px;
  letter-spacing:-0.01em;color:var(--ink);white-space:nowrap;
}
.logo::before{
  content:"";display:inline-block;width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, var(--tertiary), var(--primary) 80%);
  margin-right:10px;vertical-align:-3px;
  box-shadow:0 0 0 1px var(--primary-shadow);
}
.nav-right{display:flex;gap:16px;align-items:center;}
.nav-links{display:flex;gap:28px;align-items:center;}
.nav-links .link{
  text-decoration:none;font-size:14px;color:var(--ink-soft);
  font-weight:500;white-space:nowrap;
}
.nav-links .link:hover{color:var(--primary);}
.lang-select{
  font-family:var(--font-body);font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:0.06em;color:var(--muted);
  padding:6px 26px 6px 10px;border:1px solid var(--hairline);border-radius:999px;
  background:var(--paper) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%236A5E4D' stroke-width='1.5' d='M1 1l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 10px center;
  appearance:none;-webkit-appearance:none;cursor:pointer;
}
@media (max-width:880px){ .nav-links .link{display:none;} }

/* ===================== BUTTONS ===================== */
.btn{
  display:inline-block;font-family:var(--font-body);font-weight:600;
  text-decoration:none;cursor:pointer;border:0;text-align:center;
  transition:background .15s ease, transform .05s ease;
}
.btn-primary{
  background:var(--primary-container);color:var(--white);
  padding:13px 22px;border-radius:6px;font-size:15px;
  box-shadow:0 1px 0 var(--primary-shadow);
}
.btn-primary:hover{background:var(--primary);}
.btn-primary:active{transform:translateY(1px);}
.btn-secondary{
  background:transparent;color:var(--primary);
  padding:13px 22px;border-radius:6px;font-size:15px;
  border:1px solid var(--hairline);
}
.btn-secondary:hover{background:var(--paper-dim);border-color:var(--secondary);}
.btn-sm{padding:9px 16px;font-size:13px;}
.btn-light{
  background:var(--tertiary);color:var(--primary);
  padding:14px 26px;border-radius:6px;font-size:16px;
}
.btn-light:hover{background:var(--white);}

/* ===================== HERO ===================== */
.hero{padding:72px 0 48px;text-align:center;}
@media (max-width:720px){ .hero{padding:48px 0 32px;} }
@media (max-width:480px){ .hero{padding:36px 0 24px;} }

.eyebrow{
  display:inline-block;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:0.12em;
  color:var(--primary);background:color-mix(in srgb, var(--tertiary) 35%, transparent);
  padding:5px 12px;border-radius:999px;
}

.hero h1{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(26px, 5.5vw, 56px);line-height:1.12;letter-spacing:-0.022em;
  margin:18px auto 14px;max-width:880px;color:var(--ink);
  text-wrap:balance;overflow-wrap:break-word;padding:0 8px;
}
.hero h1 em{font-style:italic;color:var(--primary);font-weight:600;}
@media (max-width:480px){
  .hero h1{font-size:24px;line-height:1.22;letter-spacing:-0.012em;padding:0;}
}
@media (max-width:360px){ .hero h1{font-size:22px;line-height:1.25;} }

.hero .sub{
  font-size:17px;color:var(--ink-soft);max-width:560px;margin:0 auto 28px;
  line-height:1.55;text-wrap:balance;padding:0 8px;
}
@media (max-width:720px){ .hero .sub{font-size:15px;} }

.hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
@media (max-width:560px){
  .hero-ctas{flex-direction:column;align-items:stretch;max-width:320px;margin:0 auto;}
  .hero-ctas .btn{width:100%;}
}

.hero-meta{
  margin-top:20px;font-size:13px;color:var(--muted);
  display:flex;gap:20px;justify-content:center;flex-wrap:wrap;
}
.hero-meta span{display:inline-flex;align-items:center;gap:6px;}
@media (max-width:560px){ .hero-meta{gap:8px 14px;font-size:12px;} }
.dot{
  display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--secondary);flex-shrink:0;
}

/* ===================== DASHBOARD PREVIEW ===================== */
.preview-wrap{margin:56px auto 0;max-width:1140px;padding:0 16px;}
@media (max-width:720px){ .preview-wrap{padding:0 12px;margin-top:32px;} }

.preview{
  background:var(--white);border:1px solid var(--hairline);border-radius:12px;
  box-shadow:0 24px 60px -20px var(--primary-shadow),
             0 8px 16px -8px var(--primary-shadow);
  overflow:hidden;
  display:grid;grid-template-columns:220px 1fr;
}
@media (max-width:780px){
  .preview{grid-template-columns:1fr;border-radius:8px;}
  .sidebar{display:none;}
}

.preview-bar{
  grid-column:1/-1;
  height:34px;background:var(--paper-dim);border-bottom:1px solid var(--hairline-soft);
  display:flex;align-items:center;gap:6px;padding:0 12px;
}
.preview-bar i{width:10px;height:10px;border-radius:50%;background:var(--hairline);}
.preview-bar i:nth-child(1){background:#E07474;}
.preview-bar i:nth-child(2){background:#E5B158;}
.preview-bar i:nth-child(3){background:var(--secondary);}
.preview-bar .url{
  margin-left:14px;font-size:12px;color:var(--muted);
  background:var(--white);padding:3px 10px;border-radius:5px;
  border:1px solid var(--hairline-soft);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1 auto;min-width:0;
}
@media (max-width:560px){ .preview-bar .url{font-size:10px;} }

.sidebar{padding:20px 14px;background:var(--paper);border-right:1px solid var(--hairline-soft);}
.sidebar-label{
  font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--muted);padding:0 12px;margin-bottom:6px;
}
.dash-nav{
  display:flex;align-items:center;gap:10px;padding:8px 12px;
  border-radius:6px;font-size:14px;color:var(--ink-soft);font-weight:500;
  margin-bottom:2px;
}
.dash-nav .ico{
  width:14px;height:14px;border-radius:3px;background:var(--hairline);flex-shrink:0;
}
.dash-nav.active{background:color-mix(in srgb, var(--tertiary) 30%, transparent);color:var(--primary);}
.dash-nav.active .ico{background:var(--primary-container);}

.main-panel{padding:24px 28px;}
@media (max-width:560px){ .main-panel{padding:18px 16px;} }
.breadcrumb{font-size:12px;color:var(--muted);margin-bottom:10px;}
.breadcrumb b{color:var(--ink-soft);font-weight:500;}
.page-title{
  font-family:var(--font-display);font-weight:600;font-size:24px;letter-spacing:-0.015em;
  margin:0 0 20px;
}
@media (max-width:560px){ .page-title{font-size:20px;} }

.score-row{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;margin-bottom:20px;}
@media (max-width:560px){ .score-row{grid-template-columns:1fr;gap:12px;} }
.score-card{
  background:var(--paper);border:1px solid var(--hairline-soft);
  border-radius:10px;padding:20px;
}
.score-card .lbl{
  font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--muted);
}
.score-card .big{
  font-family:var(--font-body);font-weight:500;font-size:44px;
  color:var(--primary);letter-spacing:-0.03em;line-height:1;
  margin:8px 0 6px;font-variant-numeric:tabular-nums;
}
.score-card .big sup{font-size:24px;color:var(--muted);font-weight:500;}
.score-card .delta{font-size:12px;color:var(--ok);font-weight:500;}
.progress{
  margin-top:14px;height:6px;background:var(--hairline-soft);border-radius:3px;overflow:hidden;
}
.progress > i{
  display:block;height:100%;
  background:linear-gradient(90deg, var(--secondary), var(--primary-container));
  border-radius:3px;
}
.score-card.dark{background:var(--primary-container);color:var(--white);border-color:var(--primary);}
.score-card.dark .lbl{color:color-mix(in srgb, var(--tertiary) 80%, transparent);}
.score-card.dark .big{color:var(--white);}
.score-card.dark .sub{font-size:13px;color:color-mix(in srgb, var(--tertiary) 80%, transparent);}

.table-card{background:var(--white);border:1px solid var(--hairline-soft);border-radius:10px;overflow:hidden;}
.table-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 20px;border-bottom:1px solid var(--hairline-soft);
}
.table-head h3{
  margin:0;font-family:var(--font-display);font-weight:500;font-size:16px;letter-spacing:-0.005em;
}
.table-head .meta{font-size:12px;color:var(--muted);}
table.passports{width:100%;border-collapse:collapse;font-size:13px;}
table.passports th{
  text-align:left;font-weight:600;font-size:10px;text-transform:uppercase;
  letter-spacing:0.08em;color:var(--muted);
  padding:10px 20px;border-bottom:1px solid var(--hairline-soft);background:var(--paper);
}
table.passports td{
  padding:12px 20px;border-bottom:1px solid var(--hairline-soft);color:var(--ink-soft);
}
table.passports tr:last-child td{border-bottom:0;}
table.passports tr:hover td{background:color-mix(in srgb, var(--primary) 4%, transparent);}
.mono{font-family:var(--font-body);font-weight:500;font-variant-numeric:tabular-nums;
      letter-spacing:-0.005em;color:var(--ink);white-space:nowrap;}
.chip{
  display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.07em;padding:3px 8px;border-radius:999px;white-space:nowrap;
}
.chip-ok{background:color-mix(in srgb, var(--tertiary) 35%, transparent);color:var(--ok);}
.chip-warn{background:#FBF3E6;color:var(--warn);}
.chip-err{background:var(--err-soft);color:var(--err);}

@media (max-width:560px){
  table.passports thead{display:none;}
  table.passports tr{
    display:block;padding:14px 16px;border-bottom:1px solid var(--hairline-soft);
  }
  table.passports tr:last-child{border-bottom:0;}
  table.passports td{
    display:grid;grid-template-columns:80px 1fr;gap:10px;
    padding:4px 0;border:0;font-size:13px;align-items:center;
  }
  table.passports td::before{
    content:attr(data-label);font-size:10px;font-weight:600;text-transform:uppercase;
    letter-spacing:0.08em;color:var(--muted);
  }
  .table-head{padding:12px 16px;}
  .table-head h3{font-size:14px;}
}

/* ===================== TRUST STRIP ===================== */
.trust{padding:64px 0;}
@media (max-width:720px){ .trust{padding:48px 0;} }
.trust-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:40px;}
@media (max-width:720px){ .trust-grid{grid-template-columns:1fr;gap:32px;} }
.trust-item h4{
  font-family:var(--font-display);font-weight:600;font-size:20px;
  margin:0 0 6px;letter-spacing:-0.01em;
}
.trust-item p{font-size:14px;color:var(--ink-soft);line-height:1.55;margin:0;}
.trust-ico{
  width:36px;height:36px;border-radius:8px;
  background:color-mix(in srgb, var(--tertiary) 35%, transparent);
  display:flex;align-items:center;justify-content:center;
  color:var(--primary);font-weight:600;margin-bottom:14px;
  font-family:var(--font-body);font-size:14px;letter-spacing:0.02em;
}

/* ===================== VALUE PROP ===================== */
.vp{padding:64px 0;border-top:1px solid var(--hairline-soft);}
@media (max-width:720px){ .vp{padding:48px 0;} }
.vp h2{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(22px, 3.4vw, 36px);
  text-align:center;letter-spacing:-0.02em;line-height:1.2;
  max-width:760px;margin:0 auto 14px;text-wrap:balance;padding:0 8px;
}
.vp h2 em{font-style:italic;color:var(--primary);}
.vp .sub{
  text-align:center;color:var(--ink-soft);font-size:16px;max-width:560px;
  margin:0 auto 36px;line-height:1.5;text-wrap:balance;padding:0 8px;
}
.vp-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:920px;margin:0 auto;}
@media (max-width:720px){ .vp-grid{grid-template-columns:1fr;gap:16px;} }
.vp-card{background:var(--white);border:1px solid var(--hairline);border-radius:12px;padding:28px;}
@media (max-width:560px){ .vp-card{padding:22px;} }
.vp-card.accent{border-left:3px solid var(--secondary);}
.vp-card .lbl{
  font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--muted);margin-bottom:12px;
}
.vp-card h3{
  font-family:var(--font-display);font-weight:600;font-size:22px;
  margin:0 0 14px;letter-spacing:-0.01em;
}
.vp-card ul{margin:0;padding:0;list-style:none;}
.vp-card li{
  font-size:14px;color:var(--ink-soft);padding:10px 0 10px 22px;position:relative;
  border-bottom:1px solid var(--hairline-soft);line-height:1.5;
}
.vp-card li:last-child{border-bottom:0;}
.vp-card li::before{
  content:"";position:absolute;left:0;top:16px;width:12px;height:12px;
  border-radius:50%;background:color-mix(in srgb, var(--tertiary) 60%, transparent);
}
.vp-card.accent li::before{background:var(--secondary);}

/* ===================== WHY ===================== */
.why{padding:64px 0;border-top:1px solid var(--hairline-soft);max-width:760px;margin:0 auto;}
@media (max-width:720px){ .why{padding:48px 20px;} }
.why h2{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(22px, 3vw, 30px);letter-spacing:-0.02em;line-height:1.25;
  margin:0 0 16px;text-wrap:balance;
}
.why p{font-size:15px;color:var(--ink-soft);line-height:1.65;margin:0 0 14px;}

/* ===================== FINAL CTA ===================== */
.final{margin:72px 0 0;background:var(--primary-container);color:var(--white);padding:64px 0;}
@media (max-width:720px){ .final{padding:48px 0;margin-top:48px;} }
.final-inner{text-align:center;}
.final h2{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(22px, 3.4vw, 34px);
  letter-spacing:-0.02em;line-height:1.2;margin:0 auto 14px;color:var(--white);
  max-width:720px;text-wrap:balance;padding:0 12px;
}
.final p{
  font-size:16px;color:color-mix(in srgb, var(--tertiary) 88%, transparent);
  margin:0 auto 28px;max-width:560px;line-height:1.55;padding:0 12px;
}

/* ===================== FORM SECTION ===================== */
.form-section{padding:72px 0;background:linear-gradient(180deg, var(--paper) 0%, var(--paper-dim) 100%);border-top:1px solid var(--hairline-soft);}
@media (max-width:720px){ .form-section{padding:48px 0;} }
.form-intro{text-align:center;max-width:720px;margin:0 auto 36px;}
.form-intro h2{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(24px, 3.6vw, 36px);
  letter-spacing:-0.02em;line-height:1.2;margin:14px 0 12px;text-wrap:balance;
}
.form-intro .sub{font-size:16px;color:var(--ink-soft);line-height:1.55;margin:0;text-wrap:balance;}

.form-card{
  background:var(--white);border:1px solid var(--hairline);border-radius:14px;
  padding:36px 36px 28px;max-width:720px;margin:0 auto;
  box-shadow:0 24px 60px -20px var(--primary-shadow), 0 8px 16px -8px var(--primary-shadow);
}
@media (max-width:560px){ .form-card{padding:24px 20px 20px;border-radius:10px;} }

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px;margin-bottom:18px;}
@media (max-width:560px){ .form-grid{grid-template-columns:1fr;gap:14px;} }

.input-group{display:flex;flex-direction:column;gap:6px;}
.input-group label{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;
  color:var(--muted);
}
.input-group input{
  font-family:var(--font-body);font-size:15px;color:var(--ink);
  background:var(--paper);border:1px solid var(--hairline);
  border-radius:8px;padding:11px 14px;width:100%;
  transition:border-color .15s ease, background .15s ease, box-shadow .15s ease;
}
.input-group input:focus{
  outline:0;border-color:var(--primary);background:var(--white);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--tertiary) 35%, transparent);
}
.input-group input:invalid:not(:placeholder-shown){border-color:var(--err);}

.field-error{
  display:block;font-size:12px;color:var(--err);margin-top:4px;font-weight:500;
}

.drop-zone{
  display:block;border:2px dashed var(--hairline);border-radius:10px;
  background:var(--paper);padding:24px 20px;margin:18px 0 14px;text-align:center;
  cursor:pointer;transition:border-color .15s ease, background .15s ease;
  position:relative;
}
.drop-zone:hover, .drop-zone:focus-within{
  border-color:var(--secondary);background:var(--white);
}
.drop-zone.dragging{
  border-color:var(--primary);background:color-mix(in srgb, var(--tertiary) 15%, var(--white));
}
.drop-zone .drop-icon{font-size:22px;display:block;margin-bottom:8px;}
.drop-zone .drop-label{
  font-family:var(--font-display);font-weight:500;font-size:16px;color:var(--ink);
  letter-spacing:-0.005em;margin-bottom:4px;
}
.drop-zone .drop-formats{font-size:12px;color:var(--muted);}
.drop-zone .file-chosen{
  margin-top:10px;font-size:13px;color:var(--ok);font-weight:500;
  background:color-mix(in srgb, var(--tertiary) 25%, transparent);
  padding:6px 12px;border-radius:6px;display:inline-block;
}
.drop-zone input[type="file"]{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

.privacy-note{
  font-size:12px;color:var(--muted);text-align:center;margin:14px 0 18px;
  line-height:1.5;
}
.btn-full{width:100%;padding:14px 22px;font-size:16px;}

.success-msg{
  text-align:center;padding:24px 12px;
}
.success-msg .success-icon{font-size:42px;margin-bottom:10px;}
.success-msg h3{
  font-family:var(--font-display);font-weight:600;font-size:24px;
  margin:0 0 10px;color:var(--primary);letter-spacing:-0.01em;
}
.success-msg p{font-size:15px;color:var(--ink-soft);line-height:1.55;margin:0;max-width:480px;margin:0 auto;}

/* ===================== NEXT STEPS ===================== */
.next-steps{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:20px;
  max-width:1000px;margin:48px auto 0;
}
@media (max-width:780px){ .next-steps{grid-template-columns:1fr;gap:16px;} }
.next-step{
  display:flex;gap:14px;align-items:flex-start;
  background:var(--white);border:1px solid var(--hairline-soft);border-radius:10px;
  padding:18px 20px;
}
.next-num{
  width:32px;height:32px;border-radius:50%;
  background:color-mix(in srgb, var(--tertiary) 30%, transparent);
  color:var(--primary);font-family:var(--font-display);font-weight:600;font-size:16px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  letter-spacing:-0.02em;
}
.next-content h4{
  font-family:var(--font-display);font-weight:600;font-size:15px;
  margin:0 0 4px;letter-spacing:-0.005em;line-height:1.25;
}
.next-content p{font-size:13px;color:var(--ink-soft);line-height:1.5;margin:0;}

/* ===================== FOOTER ===================== */
footer{padding:32px 0;border-top:1px solid var(--hairline-soft);background:var(--paper);
       font-size:13px;color:var(--muted);}
.foot-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;align-items:center;}
.foot-links a{text-decoration:none;color:var(--muted);margin-left:20px;}
.foot-links a:first-child{margin-left:0;}
.foot-links a:hover{color:var(--primary);}
@media (max-width:560px){
  .foot-inner{flex-direction:column;align-items:flex-start;}
  .foot-links{margin-top:4px;}
  .foot-links a{margin:0 16px 0 0;}
}

@media (prefers-reduced-motion: reduce){
  *{transition:none !important;animation:none !important;}
}
