/* =========================
   Silviaemuns Founder Finance Lab
   Main styles (no folders)
   ========================= */

:root{
  --ink: #0b1220;
  --ink-2: #111a2e;
  --warm: #ff6a3d;
  --warm-deep: #e95428;
  --accent: #0ea5a5;
  --soft: #f7f8fb;
  --line: #e8ebf3;
  --muted: #5b6477;
  --shadow-1: 0 10px 28px rgba(9, 18, 39, 0.08);
  --shadow-2: 0 14px 40px rgba(9, 18, 39, 0.12);
  --radius-xl: 22px;
  --radius-lg: 16px;
  --radius-md: 12px;
}

*{ box-sizing: border-box; }

html, body{
  height: 100%;
}
section {
  margin: 25px!important;
}
body{
  margin: 0;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 18px;
  color: var(--ink);
  background-image:
    url("images/Silviaemuns-body-bg.jpg");
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  position: relative;
}

/* Optional dim layer for readability */
.bg-dim{
  position: fixed;
  inset: 0;
  background:
    radial-gradient(1200px 800px at 10% 10%, rgba(255, 255, 255, 0.06), transparent 60%),
    radial-gradient(1200px 800px at 90% 20%, rgba(255, 255, 255, 0.04), transparent 60%),
    linear-gradient(180deg, rgba(6, 10, 22, 0.08), rgba(6, 10, 22, 0.12));
  pointer-events: none;
  z-index: 0;
}

/* Layout helpers */
.container{
  width: 90%;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.section-shell{
  margin: 0 auto;
}

.flex-between{
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flex-wrap{ flex-wrap: wrap; }
.gap-sm{ gap: 10px; }

.grid-2{
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 36px;
}

@media (max-width: 980px){
  .grid-2{ grid-template-columns: 1fr; }
}

/* Topbar */
.topbar{
  position: relative;
  z-index: 2;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
  padding: 10px 0;
}

.topbar-text{
  font-size: 0.9rem;
  color: var(--muted);
}

.top-link{
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--ink);
  text-decoration: none;
}
.top-link:hover{ color: var(--warm-deep); }

.dot{
  opacity: 0.5;
  margin: 0 6px;
}

/* Pills */
.pill{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.pill-soft{
  background: #fff2ec;
  color: #8a2f12;
  border: 1px solid #ffe1d6;
}

/* Header */
.header{
  margin-top: 14px;
  margin-bottom: 18px;
  position: relative;
  z-index: 2;
}

.header .container{
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 14px 18px;
  box-shadow: var(--shadow-1);
  flex-wrap: wrap;
}

/* Brand */
.brand{
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--ink);
}

.brand-mark{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background:
    linear-gradient(135deg, var(--ink), var(--ink-2));
  color: #fff;
  display: grid;
  place-items: center;
  font-weight: 800;
  letter-spacing: 0.06em;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.06);
}
.brand-mark-sm{
  width: 36px;
  height: 36px;
  border-radius: 12px;
}

.brand-name{
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}
.brand-name-strong{
  font-family: "Space Grotesk", system-ui, sans-serif;
  font-weight: 800;
  font-size: 1.15rem;
  letter-spacing: -0.02em;
}
.brand-sub{
  font-size: 0.82rem;
  color: var(--muted);
  font-weight: 600;
}

/* Nav */
.nav{
  display: flex;
  align-items: center;
  gap: 6px;
}

.nav-link{
  text-decoration: none;
  color: var(--ink);
  font-weight: 600;
  font-size: 0.95rem;
  padding: 8px 12px;
  border-radius: 10px;
  transition: background .2s, color .2s, transform .2s;
}
.nav-link:hover{
  background: #f2f5ff;
  color: #0d1a3b;
}
.nav-link.active{
  background: #0f172a;
  color: #fff;
}

/* Header actions */
.header-actions{
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Burger for mobile */
.burger{
  display: none;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #fff;
  cursor: pointer;
  padding: 10px;
}
.burger span{
  display: block;
  height: 2px;
  background: #0f172a;
  margin: 6px 0;
  border-radius: 3px;
}

@media (max-width: 1060px){
  .nav{ display: none; }
  .burger{ display: inline-block; }
}

/* Mobile nav open state */
.nav-open{
  display: flex !important;
  position: absolute;
  right: 22px;
  top: 120px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 10px;
  flex-direction: column;
  min-width: 230px;
  box-shadow: var(--shadow-2);
  z-index: 10;
}

/* Section cards (white background with outer margins) */
.section-card{
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  margin: 22px auto;
  padding: 48px 0;
  box-shadow: var(--shadow-1);
  position: relative;
  z-index: 1;
}

/* Hero tuning */
.hero{
  padding: 56px 0 62px;
}

.eyebrow{
  display: inline-block;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #0f766e;
  background: #ecfdfb;
  border: 1px solid #c9f4ee;
  padding: 6px 10px;
  border-radius: 999px;
}

h1, h2, h3, h4{
  font-family: "Space Grotesk", system-ui, sans-serif;
  color: #0b1220;
  margin: 0 0 12px 0;
  letter-spacing: -0.02em;
}

h1{
  font-size: clamp(2rem, 3.2vw, 3rem);
  font-weight: 800;
  line-height: 1.05;
}

h2{
  font-size: clamp(1.6rem, 2.2vw, 2.1rem);
  font-weight: 800;
}

h3{
  font-size: 1.25rem;
  font-weight: 700;
}

h4{
  font-size: 1.05rem;
  font-weight: 700;
}

p{
  color: #1b2436;
  line-height: 1.6;
  margin: 0 0 14px 0;
}

.lead{
  font-size: 1.06rem;
  color: #1a2540;
}

.muted{
  color: var(--muted);
}

/* Buttons */
.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-decoration: none;
  font-weight: 700;
  border-radius: 14px;
  padding: 12px 18px;
  font-size: 0.98rem;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .15s, box-shadow .2s, background .2s, color .2s, border-color .2s;
}

.btn-sm{
  padding: 9px 14px;
  font-size: 0.9rem;
  border-radius: 12px;
}

.btn-warm{
  background: linear-gradient(135deg, var(--warm), var(--warm-deep));
  color: #fff;
  box-shadow: 0 10px 22px rgba(255, 106, 61, 0.25);
}
.btn-warm:hover{ transform: translateY(-1px); }

.btn-dark{
  background: #0f172a;
  color: #fff;
  border-color: #0f172a;
}
.btn-dark:hover{ transform: translateY(-1px); }

.btn-ghost{
  background: #fff;
  color: #0f172a;
  border-color: var(--line);
}
.btn-ghost:hover{
  background: #f6f7ff;
}

.w-full{ width: 100%; }

/* Hero extras */
.hero-cta{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 18px 0 22px;
}

.hero-metrics{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
@media (max-width: 620px){
  .hero-metrics{ grid-template-columns: 1fr; }
}

.metric{
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 14px 14px 12px;
  background: #fbfcff;
}
.metric-num{
  font-family: "Space Grotesk", system-ui, sans-serif;
  font-size: 1.6rem;
  font-weight: 800;
}
.metric-label{
  font-size: 0.9rem;
  color: var(--muted);
  font-weight: 600;
}

/* Hero visual cards */
.hero-visual{
  display: grid;
  gap: 14px;
  align-content: start;
}

.visual-card{
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 22px 22px 20px;
  background:
    linear-gradient(180deg, #ffffff, #fbfcff);
}
.visual-card.subtle{
  background: #0f172a;
  color: #fff;
  border-color: #0f172a;
}
.visual-card.subtle h4{ color: #fff; }
.visual-card.subtle p{ color: rgba(255,255,255,0.85); }

.visual-badge{
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 800;
  color: #0b1220;
  background: #eaf2ff;
  border: 1px solid #d7e6ff;
  padding: 5px 9px;
  border-radius: 999px;
  margin-bottom: 10px;
}

.visual-foot{
  margin-top: 12px;
  font-size: 0.92rem;
  color: var(--muted);
}

/* Panels */
.panel{
  border-radius: var(--radius-xl);
  padding: 26px;
  border: 1px solid var(--line);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.6);
}
.panel-accent{
  background:
    linear-gradient(135deg, #fff5f0, #ffffff);
  border-color: #ffe0d4;
}
.panel-quiet{
  background:
    linear-gradient(135deg, #f5fbff, #ffffff);
  border-color: #dfefff;
}

/* Mini grid */
.mini-grid{
  display: grid;
  gap: 12px;
  margin: 14px 0 18px;
}
.mini{
  background: #fff;
  border: 1px solid #ffe3d9;
  border-radius: var(--radius-md);
  padding: 14px;
}
.mini-title{
  font-weight: 700;
  margin-bottom: 6px;
}
.mini-text{
  font-size: 0.95rem;
  color: var(--muted);
}

/* Cards sections */
.section-head{
  margin-bottom: 22px;
}

.cards-4{
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px;
}
@media (max-width: 1100px){
  .cards-4{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 600px){
  .cards-4{ grid-template-columns: 1fr; }
}

.cards-3{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
@media (max-width: 980px){
  .cards-3{ grid-template-columns: 1fr; }
}

.card{
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 22px 20px 20px;
  background: #fff;
  transition: transform .15s, box-shadow .2s;
}
.card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-1);
}

.card-icon{
  font-family: "Space Grotesk", system-ui, sans-serif;
  font-weight: 800;
  font-size: 0.9rem;
  color: #0f172a;
  background: #eef2ff;
  border: 1px solid #dfe5ff;
  display: inline-block;
  padding: 6px 10px;
  border-radius: 10px;
  margin-bottom: 10px;
}

.text-link{
  display: inline-block;
  margin-top: 6px;
  font-weight: 700;
  text-decoration: none;
  color: #0f766e;
}
.text-link:hover{ color: #0a4d49; }

/* Case list */
.case-list{
  display: grid;
  gap: 10px;
  margin-top: 18px;
}
.case{
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 14px 14px 12px;
  background: #fbfcff;
}
.case-tag{
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #0b1220;
  background: #f1f5f9;
  border: 1px solid #e5eaf1;
  padding: 4px 8px;
  border-radius: 999px;
}
.case-title{
  font-weight: 800;
  margin-top: 6px;
}
.case-text{
  font-size: 0.95rem;
  color: var(--muted);
  margin-top: 4px;
}

/* Lists */
.clean-list{
  list-style: none;
  padding: 0;
  margin: 10px 0 0 0;
  display: grid;
  gap: 8px;
}
.dot-ok{
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), #22c55e);
  margin-right: 8px;
  transform: translateY(1px);
}

/* Forms */
.form-box{
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 22px;
  background: #fbfcff;
}

.form-row{
  display: grid;
  gap: 6px;
  margin-bottom: 14px;
}

label{
  font-weight: 700;
  font-size: 0.92rem;
}

input, select, textarea{
  font: inherit;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid #e4e8f2;
  background: #fff;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
input:focus, select:focus, textarea:focus{
  border-color: #c9d6ff;
  box-shadow: 0 0 0 4px rgba(91, 124, 255, 0.12);
}

.form-hint{
  font-size: 0.85rem;
  color: var(--muted);
  margin-top: 10px;
}

/* Newsletter */
.newsletter{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  background: #fbfcff;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 14px;
}
.newsletter input{
  border-radius: 12px;
}
@media (max-width: 520px){
  .topbar {
    display: none;
  }
  .newsletter{ grid-template-columns: 1fr; }
  .newsletter .btn{ width: 100%; }
}

/* Quotes */
.quote{
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 22px;
  background:
    linear-gradient(180deg, #ffffff, #fbfcff);
}
.quote p{
  font-weight: 600;
}
.quote-foot{
  margin-top: 10px;
  font-size: 0.9rem;
  color: var(--muted);
  font-weight: 700;
}

/* Footer */
.footer{
  background: #0b1220;
  color: #eef2ff;
  border-radius: var(--radius-xl);
  padding: 50px 0 18px;
  margin: 22px auto 30px;
}

.footer .container{
  width: min(1200px, 92%);
}

.grid-foot{
  display: grid;
  grid-template-columns: 1.4fr 0.6fr 0.6fr 0.7fr;
  gap: 26px;
}
@media (max-width: 980px){
  .grid-foot{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px){
  .grid-foot{ grid-template-columns: 1fr; }
}

.brand-inline{
  display: flex;
  gap: 10px;
  align-items: center;
}

.foot-title{
  font-family: "Space Grotesk", system-ui, sans-serif;
  font-weight: 800;
  font-size: 1.15rem;
}
.foot-sub{
  font-size: 0.85rem;
  opacity: 0.75;
  font-weight: 600;
}
.foot-text{
  margin-top: 12px;
  font-size: 0.95rem;
  color: rgba(238, 242, 255, 0.82);
}

.foot-col-title{
  font-weight: 800;
  font-size: 0.95rem;
  margin-bottom: 10px;
}

.foot-link{
  display: block;
  text-decoration: none;
  color: rgba(238, 242, 255, 0.85);
  font-size: 0.95rem;
  margin: 6px 0;
  font-weight: 600;
}
.foot-link:hover{
  color: #fff;
}

.footer a{ color: inherit; }

.foot-bottom{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: center;
  margin-top: 28px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 0.85rem;
  opacity: 0.75;
  text-align: center;
}
.foot-divider{ opacity: 0.45; }

/* Cookie banner */
.cookie-banner{
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 50;
  display: none;
}
.cookie-banner.show{ display: block; }

.cookie-inner{
  width: min(980px, 100%);
  margin: 0 auto;
  background: #0f172a;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 18px 18px 16px;
  box-shadow: 0 18px 50px rgba(0,0,0,0.25);
}

.cookie-title{
  font-weight: 800;
  font-size: 1.05rem;
  margin-bottom: 6px;
  font-family: "Space Grotesk", system-ui, sans-serif;
}
.cookie-text{
  font-size: 0.92rem;
  opacity: 0.85;
  line-height: 1.45;
}
.cookie-text a{
  color: #ffd2c4;
  font-weight: 700;
}
.cookie-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

/* Modal */
.modal{
  position: fixed;
  inset: 0;
  z-index: 60;
  display: none;
}
.modal.show{ display: block; }

.modal-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(2, 6, 23, 0.55);
  backdrop-filter: blur(4px);
}

.modal-card{
  position: relative;
  width: min(520px, 92%);
  margin: 10vh auto 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 28px 26px 24px;
  box-shadow: var(--shadow-2);
  text-align: center;
}

.modal-icon{
  width: 56px;
  height: 56px;
  border-radius: 18px;
  margin: 0 auto 12px;
  display: grid;
  place-items: center;
  font-weight: 900;
  font-size: 1.4rem;
  color: #fff;
  background: linear-gradient(135deg, var(--accent), #22c55e);
}

/* Utility */
.mt-6{ margin-top: 6px; }
