/* OPPI affiliation landing pages — brand system pulled from live oppischools.fi.
   Jost headings + DM Sans body; indigo + amber + cream. */

:root{
  --indigo:#2a295f;
  --indigo-deep:#1a1845;
  --indigo-2:#23215a;
  --amber:#c5af7a;
  --gold:#f2b441;
  --cream:#f8f7f4;
  --cream-2:#e8e6e0;
  --orange:#e05a1c;
  --ink:#1a1845;
  --line:rgba(197,175,122,.28);
  --r:14px;
  --r-sm:8px;
  --maxw:1180px;
  --shadow:0 24px 60px -24px rgba(10,9,40,.55);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  font-weight:300;
  color:#efeefb;
  background:var(--indigo-deep);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
  min-height:100vh;
  position:relative;
  overflow-x:hidden;
}

/* background layers */
.bg{position:fixed;inset:0;z-index:0;pointer-events:none}
.bg-grad{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(91,87,201,.45) 0%, transparent 55%),
    radial-gradient(90% 80% at 0% 100%, rgba(42,41,95,.6) 0%, transparent 60%),
    linear-gradient(160deg, #23215a 0%, #1a1845 55%, #14132f 100%);
}
#constellation{position:absolute;inset:0;width:100%;height:100%;opacity:.55}
.bg-grain{
  position:absolute;inset:0;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* shell */
.wrap{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 24px}

header.nav{
  position:relative;z-index:3;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 0;
}
.nav .brand{display:flex;align-items:center;gap:12px}
.nav .brand img{height:60px;width:auto;display:block}
.nav .brand-text{font-family:'Jost',sans-serif;font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:14px;color:#efeefb}
.nav .backed{font-family:'DM Sans',sans-serif;font-size:12.5px;color:var(--amber);opacity:.9;letter-spacing:.02em}

/* hero grid */
.hero{
  display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;
  padding:40px 0 72px;min-height:calc(100vh - 90px);
}
.pitch .eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--line);border-radius:999px;
  padding:7px 15px;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--amber);font-family:'Jost',sans-serif;font-weight:600;margin-bottom:22px;
}
.pitch .eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold)}
.pitch h1{
  font-family:'DM Sans',sans-serif;font-weight:500;
  font-size:clamp(34px,4.6vw,58px);line-height:1.04;letter-spacing:-.015em;
  color:#fff;margin-bottom:20px;
}
.pitch h1 .accent{color:var(--gold)}
.pitch .sub{font-size:clamp(16px,1.4vw,19px);color:#cfceea;max-width:33ch;margin-bottom:30px}
.pitch ul.points{list-style:none;display:grid;gap:13px;margin-bottom:30px}
.pitch ul.points li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px;color:#dedcf2}
.pitch ul.points li .tick{
  flex:0 0 22px;height:22px;border-radius:50%;margin-top:1px;
  background:rgba(197,175,122,.16);border:1px solid var(--line);
  display:grid;place-items:center;color:var(--gold);font-size:12px;
}
.trust{display:flex;align-items:center;gap:15px;flex-wrap:wrap;margin-top:4px}
.trust .lbl{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);opacity:.85}
.trust img.logo-fges{height:29px;width:auto;opacity:.95}
.trust .partner-text{font-family:'Jost',sans-serif;font-weight:600;letter-spacing:.04em;color:#e7e6f5;font-size:15px}
.trust .sep{color:rgba(197,175,122,.5)}

/* form card */
.card{
  background:var(--cream);color:var(--ink);
  border-radius:20px;padding:30px 30px 26px;box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.5);
}
.card .ribbon{font-family:'Jost',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:var(--orange);margin-bottom:6px}
.card h2{font-family:'Jost',sans-serif;font-weight:700;font-size:22px;color:var(--indigo);letter-spacing:.01em;margin-bottom:4px}
.card .card-sub{font-size:14px;color:#5a597a;margin-bottom:20px}
.field{margin-bottom:13px}
.field label{display:block;font-size:12.5px;font-weight:600;color:#3a3960;margin-bottom:5px;font-family:'DM Sans',sans-serif}
.field input,.field select,.field textarea{
  width:100%;font-family:'DM Sans',sans-serif;font-size:15px;color:var(--ink);
  background:#fff;border:1px solid #ddd9cf;border-radius:10px;padding:11px 13px;outline:none;
  transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(197,175,122,.22)}
.field textarea{resize:vertical;min-height:64px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.consent{display:flex;gap:9px;align-items:flex-start;margin:6px 0 16px;font-size:12.5px;color:#5a597a}
.consent input{margin-top:3px;flex:0 0 auto}
.btn{
  width:100%;border:none;cursor:pointer;font-family:'Jost',sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;font-size:14.5px;color:var(--indigo-deep);
  background:linear-gradient(180deg,#f7cf5f,#eab12f);border-radius:11px;padding:15px;
  box-shadow:0 12px 24px -10px rgba(234,177,47,.7);transition:transform .08s,filter .15s;
}
.btn:hover{filter:brightness(1.04)}
.btn:active{transform:translateY(1px)}
.btn[disabled]{opacity:.6;cursor:default}
.card .fineprint{text-align:center;font-size:11.5px;color:#8a89a0;margin-top:12px}

/* success */
.success{display:none;text-align:center;padding:18px 6px}
.success .ok{width:56px;height:56px;border-radius:50%;background:rgba(63,182,107,.14);color:#2e9c54;display:grid;place-items:center;margin:6px auto 16px;font-size:26px}
.success h2{font-family:'Jost',sans-serif;color:var(--indigo);font-size:22px;margin-bottom:8px}
.success p{font-size:14.5px;color:#5a597a;max-width:30ch;margin:0 auto}
.card.done .formwrap{display:none}
.card.done .success{display:block}

footer.foot{position:relative;z-index:2;border-top:1px solid rgba(197,175,122,.18);margin-top:20px}
footer.foot .wrap{display:flex;align-items:center;justify-content:space-between;padding:22px 24px;flex-wrap:wrap;gap:12px}
footer.foot small{color:#9b9ac0;font-size:12.5px}
footer.foot .links a{color:var(--amber);text-decoration:none;font-size:12.5px;margin-left:18px}

@media (max-width:860px){
  .hero{grid-template-columns:1fr;gap:34px;padding:18px 0 48px;min-height:0}
  .pitch{order:1}.formcol{order:2}
  .pitch h1{max-width:none}.pitch .sub{max-width:none}
  .nav .brand-text{display:none}
}
