/* ===== KURUMSAL ETKiNLiK TASARIM REHBERi — Premium Stage Theme ===== */

/* ---------- Custom Properties ---------- */
:root {
  --clr-bg-deep: #0a0a0f;
  --clr-bg-surface: #111118;
  --clr-bg-card: #16161f;
  --clr-bg-elevated: #1c1c28;

  --clr-gold: #d4a24e;
  --clr-gold-bright: #f0c05a;
  --clr-gold-glow: rgba(212,162,78,.15);
  --clr-gold-dim: rgba(212,162,78,.06);
  --clr-magenta: #c2185b;
  --clr-magenta-glow: rgba(194,24,91,.10);
  --clr-blue-stage: #1a237e;

  --clr-text: #e8e6e3;
  --clr-text-secondary: #8a8895;
  --clr-text-dim: #5a5868;

  --clr-border: rgba(255,255,255,.06);
  --clr-border-accent: rgba(212,162,78,.25);

  --clr-white: #ffffff;
  --clr-error: #ef5350;
  --clr-success: #66bb6a;

  --ff-body: "Segoe UI", system-ui, -apple-system, sans-serif;
  --ff-heading: "Segoe UI", system-ui, -apple-system, sans-serif;

  --fs-xs: .75rem;
  --fs-sm: .875rem;
  --fs-base: 1rem;
  --fs-md: 1.125rem;
  --fs-lg: 1.375rem;
  --fs-xl: 1.75rem;
  --fs-2xl: clamp(1.75rem, 3.5vw, 2.5rem);
  --fs-3xl: clamp(2.25rem, 5vw, 3.5rem);

  --radius: 8px;
  --radius-lg: 16px;
  --radius-xl: 24px;

  --shadow-glow-sm: 0 0 20px rgba(212,162,78,.08);
  --shadow-glow-md: 0 0 40px rgba(212,162,78,.12);
  --shadow-glow-lg: 0 4px 60px rgba(212,162,78,.15);
  --shadow-card: 0 8px 32px rgba(0,0,0,.4);

  --container: 1140px;
  --gap: 1.5rem;
  --header-h: 72px;
  --transition-smooth: .45s cubic-bezier(.25,.46,.45,.94);
  --transition-bounce: .5s cubic-bezier(.34,1.56,.64,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 1.5rem)}
body{
  font-family:var(--ff-body);font-size:var(--fs-base);line-height:1.75;
  color:var(--clr-text);background:var(--clr-bg-deep);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:var(--clr-gold);text-decoration:none;transition:color var(--transition-smooth)}
a:hover{color:var(--clr-gold-bright)}
ul,ol{list-style:none}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer}

/* ---------- Body scroll lock ---------- */
body.menu-open{overflow:hidden}

/* ---------- Custom Scrollbar ---------- */
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--clr-bg-deep)}
::-webkit-scrollbar-thumb{background:var(--clr-bg-elevated);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--clr-gold-dim)}

/* ---------- Noise Texture Overlay ---------- */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Skip Link ---------- */
.skip-link{
  position:absolute;top:-100%;left:1rem;
  background:var(--clr-gold);color:var(--clr-bg-deep);
  padding:.6rem 1.25rem;border-radius:var(--radius);
  font-weight:700;z-index:10000;
  transition:top .2s;
}
.skip-link:focus{top:.75rem}

/* ---------- Focus ---------- */
:focus-visible{
  outline:2px solid var(--clr-gold);
  outline-offset:3px;
  box-shadow:0 0 0 6px rgba(212,162,78,.12);
}

/* ---------- Container ---------- */
.container{
  width:100%;max-width:var(--container);
  margin:0 auto;padding:0 var(--gap);
}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--header-h);
  background:rgba(10,10,15,.6);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--clr-border);
  display:flex;align-items:center;
  transition:background var(--transition-smooth),border-color var(--transition-smooth),box-shadow var(--transition-smooth);
}
.site-header--scrolled{
  background:rgba(10,10,15,.92);
  border-bottom-color:var(--clr-border-accent);
  box-shadow:0 4px 30px rgba(0,0,0,.3),0 1px 0 rgba(212,162,78,.08);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between}
.site-logo{
  font-size:var(--fs-lg);font-weight:900;
  color:var(--clr-white);letter-spacing:-.03em;
  transition:transform var(--transition-smooth);
}
.site-logo:hover{transform:scale(1.03);color:var(--clr-white)}
.site-logo span{color:var(--clr-gold)}

/* Nav — desktop */
.main-nav{display:flex;align-items:center;gap:2px}
.main-nav a{
  color:var(--clr-text-secondary);
  padding:.45rem .65rem;font-size:var(--fs-xs);font-weight:500;
  white-space:nowrap;
  border-radius:var(--radius);
  position:relative;
  transition:color var(--transition-smooth),background var(--transition-smooth);
}
.main-nav a::after{
  content:"";position:absolute;bottom:2px;left:50%;
  width:0;height:2px;
  background:var(--clr-gold);border-radius:1px;
  transition:width var(--transition-smooth),left var(--transition-smooth);
}
.main-nav a:hover{color:var(--clr-text);background:rgba(255,255,255,.04)}
.main-nav a:hover::after{width:60%;left:20%}
.main-nav a.active{color:var(--clr-gold)}
.main-nav a.active::after{width:60%;left:20%}

/* Burger — hidden on desktop */
.burger{display:none;background:none;border:none;padding:.5rem;color:var(--clr-text);position:relative;z-index:200}
.burger svg{width:24px;height:24px;transition:transform .3s}

/* Nav — mobile/tablet overlay */
@media (max-width:960px) {
  .burger{display:flex;align-items:center;justify-content:center}
  .main-nav{
    position:fixed;top:0;left:0;
    width:100vw;height:100vh;height:100dvh;
    z-index:99;
    background:#000000;
    flex-direction:column;gap:0;
    padding:calc(var(--header-h) + 2rem) 1.5rem 2rem;
    justify-content:flex-start;align-items:stretch;
    overflow-y:auto;
    opacity:0;visibility:hidden;
    transition:opacity .35s ease,visibility .35s ease;
  }
  .main-nav.open{opacity:1;visibility:visible}
  .main-nav a{
    padding:clamp(.7rem,2vh,1.1rem) 1.5rem;
    width:100%;
    font-size:clamp(var(--fs-sm),2.5vh,var(--fs-md));
    font-weight:600;
    text-align:center;
    border-radius:var(--radius);
    color:var(--clr-text-secondary);
    transition:color .25s,background .25s;
  }
  .main-nav a:hover,.main-nav a.active{
    background:rgba(212,162,78,.08);color:var(--clr-gold);
  }
  .main-nav a::after{display:none}
}

/* Small phones — tighter spacing */
@media (max-width:960px) and (max-height:600px) {
  .main-nav{padding:calc(var(--header-h) + .5rem) 1rem 1rem}
  .main-nav a{padding:.5rem 1.5rem;font-size:var(--fs-sm)}
}

/* ---------- Page Load Animations ---------- */
body{opacity:0;transition:opacity .4s ease}
body.page-loaded{opacity:1}

.hero-inner>*{
  opacity:0;transform:translateY(30px);
  transition:opacity .7s ease,transform .7s ease;
}
body.page-loaded .hero-inner>*{opacity:1;transform:translateY(0)}
body.page-loaded .hero-inner>:nth-child(1){transition-delay:.15s}
body.page-loaded .hero-inner>:nth-child(2){transition-delay:.3s}
body.page-loaded .hero-inner>:nth-child(3){transition-delay:.5s}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;
  display:flex;align-items:center;
  background:var(--clr-bg-deep);
  position:relative;overflow:hidden;
  padding:calc(var(--header-h) + 3rem) 0 5rem;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 20% 50%, rgba(26,35,126,.25), transparent),
    radial-gradient(ellipse 500px 350px at 80% 30%, rgba(194,24,91,.08), transparent);
  pointer-events:none;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle 1px at 15% 25%, rgba(255,255,255,.15) 0, transparent 1px),
    radial-gradient(circle 1px at 45% 65%, rgba(255,255,255,.1) 0, transparent 1px),
    radial-gradient(circle 1px at 75% 15%, rgba(255,255,255,.12) 0, transparent 1px),
    radial-gradient(circle 1px at 85% 75%, rgba(255,255,255,.08) 0, transparent 1px),
    radial-gradient(circle 1px at 55% 45%, rgba(255,255,255,.1) 0, transparent 1px);
  pointer-events:none;opacity:.5;
}
.hero-inner{position:relative;z-index:2;max-width:720px}
.hero h1{
  font-size:var(--fs-3xl);font-weight:900;
  line-height:1.1;margin-bottom:1.25rem;
  letter-spacing:-.03em;
  background:linear-gradient(135deg, var(--clr-white) 0%, var(--clr-gold) 50%, var(--clr-white) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.hero h1 em{
  font-style:normal;
  background:linear-gradient(135deg, var(--clr-gold-bright), var(--clr-gold));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.hero p{
  font-size:var(--fs-md);color:var(--clr-text-secondary);
  max-width:560px;margin-bottom:2.5rem;line-height:1.8;
}
.hero-cta{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.85rem 2rem;border-radius:50px;
  background:linear-gradient(135deg, var(--clr-gold), var(--clr-gold-bright));
  color:var(--clr-bg-deep);
  font-weight:700;border:none;position:relative;overflow:hidden;
  transition:transform var(--transition-smooth),box-shadow var(--transition-smooth);
}
.hero-cta::before{
  content:"";position:absolute;top:0;left:-100%;
  width:100%;height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.3), transparent);
  transition:left .6s;
}
.hero-cta:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-glow-lg);
  color:var(--clr-bg-deep);
}
.hero-cta:hover::before{left:100%}

/* Spotlights */
.spotlight{
  position:absolute;border-radius:50%;
  filter:blur(120px);pointer-events:none;
  will-change:transform;
}
.spotlight--1{
  width:400px;height:400px;
  background:var(--clr-gold);opacity:.12;
  top:-80px;right:5%;
  animation:spotlightDrift1 18s ease-in-out infinite alternate;
}
.spotlight--2{
  width:350px;height:350px;
  background:var(--clr-blue-stage);opacity:.2;
  bottom:-100px;left:8%;
  animation:spotlightDrift2 22s ease-in-out infinite alternate;
}
@keyframes spotlightDrift1{
  0%{transform:translate(0,0)}
  50%{transform:translate(-40px,30px)}
  100%{transform:translate(20px,-20px)}
}
@keyframes spotlightDrift2{
  0%{transform:translate(0,0)}
  50%{transform:translate(30px,-25px)}
  100%{transform:translate(-20px,15px)}
}

/* Hero canvas for light beams */
#hero-canvas{
  position:absolute;inset:0;z-index:1;
  width:100%;height:100%;pointer-events:none;
  opacity:.35;
}

/* ---------- Sections ---------- */
.section{padding:6rem 0;position:relative}
.section--alt{background:var(--clr-bg-surface)}

.section-label{
  display:inline-flex;align-items:center;gap:.75rem;
  font-size:var(--fs-xs);font-weight:700;text-transform:uppercase;
  letter-spacing:.25em;color:var(--clr-gold);
  margin-bottom:.75rem;
}
.section-label::after{
  content:"";display:block;width:40px;height:1px;
  background:linear-gradient(90deg, var(--clr-gold), transparent);
}
.section-title{
  font-size:var(--fs-2xl);font-weight:900;
  line-height:1.15;margin-bottom:1rem;color:var(--clr-white);
  letter-spacing:-.02em;
}
.section-lead{
  font-size:var(--fs-md);color:var(--clr-text-secondary);
  max-width:640px;margin-bottom:3rem;line-height:1.8;
}

/* Section divider beam */
.section + .section::before{
  content:"";display:block;position:absolute;top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg, transparent 10%, var(--clr-gold-dim) 30%, rgba(212,162,78,.15) 50%, var(--clr-gold-dim) 70%, transparent 90%);
}

/* ---------- Placeholder Visual Panels ---------- */
.visual-panel{
  background:var(--clr-bg-card);
  border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);
  padding:2.5rem;position:relative;overflow:hidden;
  min-height:240px;display:flex;align-items:center;justify-content:center;
  transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth);
}
.visual-panel::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle 300px at 30% 40%, rgba(212,162,78,.04), transparent),
    repeating-linear-gradient(90deg,rgba(255,255,255,.02) 0 1px,transparent 1px 50px),
    repeating-linear-gradient(0deg,rgba(255,255,255,.02) 0 1px,transparent 1px 50px);
}
.visual-panel:hover{border-color:var(--clr-border-accent);box-shadow:var(--shadow-glow-sm)}
.visual-panel svg{position:relative;z-index:1;opacity:.5}

/* ---------- Content Images ---------- */
.content-image{
  border-radius:var(--radius-lg);
  width:100%;height:auto;
  object-fit:cover;display:block;
  border:1px solid var(--clr-border);
  transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth);
}
.content-image:hover{border-color:var(--clr-border-accent);box-shadow:var(--shadow-glow-sm)}

/* ---------- Card Grid ---------- */
.card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:var(--gap);
}
.card{
  background:var(--clr-bg-card);
  border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);
  padding:2rem;position:relative;overflow:hidden;
  transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth),transform var(--transition-smooth);
}
/* Mouse-tracking glow layer */
.card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle 280px at var(--mouse-x,50%) var(--mouse-y,50%), var(--clr-gold-glow), transparent);
  opacity:0;transition:opacity var(--transition-smooth);
  pointer-events:none;border-radius:inherit;
}
.card:hover{
  border-color:var(--clr-border-accent);
  box-shadow:var(--shadow-glow-sm);
  transform:translateY(-4px);
}
.card:hover::before{opacity:1}
.card-icon{
  width:52px;height:52px;
  background:rgba(212,162,78,.08);
  border:1px solid rgba(212,162,78,.15);
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.25rem;
  transition:box-shadow var(--transition-smooth);
}
.card:hover .card-icon{box-shadow:0 0 20px rgba(212,162,78,.15)}
.card-icon svg{width:24px;height:24px;stroke:var(--clr-gold);fill:none;stroke-width:2}
.card h3{font-size:var(--fs-lg);font-weight:700;margin-bottom:.5rem;color:var(--clr-white)}
.card p{color:var(--clr-text-secondary);font-size:var(--fs-sm);line-height:1.75}

/* ---------- Two Column ---------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.two-col h3{font-size:var(--fs-xl);font-weight:700;color:var(--clr-white);margin-bottom:.75rem}
.two-col p{color:var(--clr-text-secondary);line-height:1.8;margin-bottom:.75rem}

/* ---------- Interactive Panel ---------- */
.panel-tool{
  background:var(--clr-bg-card);
  border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);
  overflow:visible;
  transition:border-color var(--transition-smooth);
}
.panel-tool:hover{border-color:var(--clr-border-accent)}
.panel-tool-header{
  background:linear-gradient(135deg, var(--clr-bg-elevated), var(--clr-bg-card));
  color:var(--clr-white);
  padding:1.25rem 2rem;
  font-weight:700;font-size:var(--fs-lg);
  display:flex;align-items:center;gap:.75rem;
  border-bottom:1px solid var(--clr-border);
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  position:relative;overflow:hidden;
}
.panel-tool-header::after{
  content:"";position:absolute;bottom:0;left:0;right:0;
  height:1px;background:linear-gradient(90deg, var(--clr-gold), transparent 70%);
}
.panel-tool-header svg{width:20px;height:20px;stroke:var(--clr-gold);fill:none;stroke-width:2}
.panel-tool-body{padding:2rem;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.panel-form{display:flex;flex-direction:column;gap:1.25rem}
.panel-form label{font-weight:600;font-size:var(--fs-sm);color:var(--clr-text);display:block;margin-bottom:.35rem}
.panel-form select,
.panel-form input[type="number"]{
  width:100%;padding:.65rem .9rem;
  border:1px solid var(--clr-border);border-radius:var(--radius);
  background:var(--clr-bg-deep);color:var(--clr-text);
  transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth);
}
.panel-form select option{background:var(--clr-bg-deep);color:var(--clr-text)}
.panel-form select:focus,
.panel-form input[type="number"]:focus{
  border-color:var(--clr-gold);outline:none;
  box-shadow:0 0 0 3px var(--clr-gold-glow);
}
.panel-result{
  background:var(--clr-bg-deep);
  border:1px solid var(--clr-border);
  border-radius:var(--radius);
  padding:1.75rem;min-height:200px;
  position:relative;overflow:hidden;
}
.panel-result::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(255,255,255,.01) 2px, rgba(255,255,255,.01) 4px);
  pointer-events:none;
}
.panel-result h4{
  font-size:var(--fs-xs);font-weight:700;color:var(--clr-gold);
  margin-bottom:.5rem;margin-top:1rem;
  text-transform:uppercase;letter-spacing:.1em;
}
.panel-result h4:first-child{margin-top:0}
.panel-result p{font-size:var(--fs-sm);color:var(--clr-text-secondary);line-height:1.75}

.btn-generate{
  align-self:flex-start;
  padding:.7rem 1.75rem;border:none;border-radius:50px;
  background:linear-gradient(135deg, var(--clr-gold), var(--clr-gold-bright));
  color:var(--clr-bg-deep);font-weight:700;
  position:relative;overflow:hidden;
  transition:transform var(--transition-smooth),box-shadow var(--transition-smooth);
}
.btn-generate::before{
  content:"";position:absolute;top:0;left:-100%;
  width:100%;height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.3), transparent);
  transition:left .5s;
}
.btn-generate:hover{transform:translateY(-1px);box-shadow:var(--shadow-glow-md)}
.btn-generate:hover::before{left:100%}

/* ---------- FAQ ---------- */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--clr-border)}
.faq-question{
  width:100%;background:none;border:none;
  text-align:left;padding:1.25rem 0;
  font-size:var(--fs-md);font-weight:600;color:var(--clr-text);
  display:flex;justify-content:space-between;align-items:center;
  gap:1rem;cursor:pointer;
  transition:color var(--transition-smooth);
}
.faq-question:hover{color:var(--clr-gold)}
.faq-question::after{
  content:"+";font-size:var(--fs-xl);color:var(--clr-gold);
  transition:transform .3s;flex-shrink:0;font-weight:300;
}
.faq-item.open .faq-question{color:var(--clr-gold)}
.faq-item.open .faq-question::after{content:"\2212"}
.faq-answer{
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.25,.46,.45,.94);
}
.faq-item.open .faq-answer{border-left:2px solid var(--clr-gold)}
.faq-answer-inner{
  padding:0 0 1.5rem 1rem;
  font-size:var(--fs-sm);color:var(--clr-text-secondary);line-height:1.85;
}

/* ---------- Risk Grid ---------- */
.risk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.risk-card{
  background:var(--clr-bg-card);
  border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);padding:1.75rem;
  border-left:3px solid var(--clr-gold);
  transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth),transform var(--transition-smooth);
}
.risk-card:hover{
  border-color:var(--clr-border-accent);
  box-shadow:var(--shadow-glow-sm);
  transform:translateY(-3px);
}
.risk-card h3{font-size:var(--fs-base);font-weight:700;margin-bottom:.5rem;color:var(--clr-white)}
.risk-card p{font-size:var(--fs-sm);color:var(--clr-text-secondary);line-height:1.75}

/* ---------- Contact Form ---------- */
.contact-form{
  background:var(--clr-bg-card);
  border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);
  padding:2.5rem;
}
.form-group{margin-bottom:1.5rem}
.form-group label{display:block;font-weight:600;font-size:var(--fs-sm);margin-bottom:.4rem;color:var(--clr-text)}
.form-group .required-star{color:var(--clr-gold)}
.form-group input,
.form-group textarea{
  width:100%;padding:.7rem .9rem;
  border:1px solid var(--clr-border);border-radius:var(--radius);
  background:var(--clr-bg-deep);color:var(--clr-text);
  transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth);
}
.form-group input:focus,
.form-group textarea:focus{
  border-color:var(--clr-gold);outline:none;
  box-shadow:0 0 0 3px var(--clr-gold-glow);
}
.form-group textarea{resize:vertical;min-height:130px}
.form-group .field-error{font-size:var(--fs-xs);color:var(--clr-error);margin-top:.3rem;display:none}
.form-group.has-error input,
.form-group.has-error textarea{border-color:var(--clr-error)}
.form-group.has-error .field-error{display:block}
.form-consent{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:1.75rem}
.form-consent input[type="checkbox"]{margin-top:.3rem;accent-color:var(--clr-gold)}
.form-consent label{font-size:var(--fs-xs);color:var(--clr-text-secondary);line-height:1.6;cursor:pointer}
.btn-submit{
  padding:.85rem 2rem;border:none;border-radius:50px;
  background:linear-gradient(135deg, var(--clr-gold), var(--clr-gold-bright));
  color:var(--clr-bg-deep);font-weight:700;width:100%;
  position:relative;overflow:hidden;
  transition:transform var(--transition-smooth),box-shadow var(--transition-smooth);
}
.btn-submit::before{
  content:"";position:absolute;top:0;left:-100%;
  width:100%;height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.3), transparent);
  transition:left .5s;
}
.btn-submit:hover{transform:translateY(-1px);box-shadow:var(--shadow-glow-md)}
.btn-submit:hover::before{left:100%}
.btn-submit:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.form-feedback{
  margin-top:1.25rem;padding:.85rem 1.25rem;
  border-radius:var(--radius);font-size:var(--fs-sm);
  display:none;
}
.form-feedback.success{display:block;background:rgba(102,187,106,.1);color:var(--clr-success);border:1px solid rgba(102,187,106,.25)}
.form-feedback.error{display:block;background:rgba(239,83,80,.1);color:var(--clr-error);border:1px solid rgba(239,83,80,.25)}

/* Honeypot */
.hn-field{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* ---------- Contact Info ---------- */
.contact-info{
  display:grid;grid-template-columns:1fr 1fr;gap:1rem;
}
.contact-info-item{
  display:flex;align-items:center;gap:1rem;
  background:var(--clr-bg-card);
  border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);
  padding:1.25rem 1.5rem;
  transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth),transform var(--transition-smooth);
}
.contact-info-item:hover{
  border-color:var(--clr-border-accent);
  box-shadow:var(--shadow-glow-sm);
  transform:translateY(-2px);
}
.contact-info-item .contact-icon{
  width:48px;height:48px;flex-shrink:0;
  background:rgba(212,162,78,.08);
  border:1px solid rgba(212,162,78,.15);
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  transition:box-shadow var(--transition-smooth);
}
.contact-info-item:hover .contact-icon{
  box-shadow:0 0 20px rgba(212,162,78,.15);
}
.contact-info-item svg{width:22px;height:22px;stroke:var(--clr-gold);fill:none;stroke-width:1.8;flex-shrink:0}
.contact-info-item .contact-text{display:flex;flex-direction:column;gap:.15rem;min-width:0}
.contact-info-item .contact-label{font-size:var(--fs-xs);color:var(--clr-text-dim);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.contact-info-item .contact-value{font-size:var(--fs-sm);color:var(--clr-text);font-weight:500;word-break:break-word}
@media (max-width:600px){
  .contact-info{grid-template-columns:1fr}
}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--clr-bg-surface);
  color:var(--clr-text-secondary);
  padding:4rem 0 1.5rem;
  position:relative;
}
.site-footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(212,162,78,.12), transparent);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;
  gap:2.5rem;margin-bottom:3rem;
}
.footer-brand{font-size:var(--fs-lg);font-weight:900;color:var(--clr-white);margin-bottom:.75rem;letter-spacing:-.02em}
.footer-brand span{color:var(--clr-gold)}
.footer-desc{font-size:var(--fs-sm);max-width:320px;line-height:1.7}
.footer-heading{font-size:var(--fs-xs);font-weight:700;color:var(--clr-text-dim);margin-bottom:.85rem;text-transform:uppercase;letter-spacing:.15em}
.footer-links a{
  display:block;font-size:var(--fs-sm);color:var(--clr-text-secondary);
  padding:.3rem 0;position:relative;
  transition:color var(--transition-smooth);
}
.footer-links a::after{
  content:"";position:absolute;bottom:2px;left:0;
  width:0;height:1px;background:var(--clr-gold);
  transition:width var(--transition-smooth);
}
.footer-links a:hover{color:var(--clr-gold)}
.footer-links a:hover::after{width:100%}
.footer-bottom{
  border-top:1px solid var(--clr-border);
  padding-top:1.5rem;
  font-size:var(--fs-xs);
  display:flex;justify-content:space-between;align-items:center;
  color:var(--clr-text-dim);
}

/* ---------- Cookie Banner ---------- */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9000;
  background:rgba(17,17,24,.9);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  padding:1.5rem;
  transform:translateY(100%);
  transition:transform .5s cubic-bezier(.25,.46,.45,.94);
  border-top:1px solid var(--clr-gold-dim);
}
.cookie-banner.visible{transform:translateY(0)}
.cookie-inner{max-width:var(--container);margin:0 auto;display:flex;align-items:center;gap:2rem;flex-wrap:wrap}
.cookie-text{flex:1;min-width:260px;font-size:var(--fs-sm);line-height:1.7;color:var(--clr-text-secondary)}
.cookie-text a{color:var(--clr-gold);text-decoration:underline}
.cookie-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cookie-btn{
  padding:.55rem 1.35rem;border-radius:50px;
  font-size:var(--fs-sm);font-weight:600;
  border:1px solid transparent;
  transition:all var(--transition-smooth);
}
.cookie-btn--accept{
  background:linear-gradient(135deg, var(--clr-gold), var(--clr-gold-bright));
  color:var(--clr-bg-deep);
}
.cookie-btn--accept:hover{box-shadow:var(--shadow-glow-sm);transform:translateY(-1px)}
.cookie-btn--reject{background:transparent;border-color:var(--clr-border-accent);color:var(--clr-text)}
.cookie-btn--reject:hover{border-color:var(--clr-gold);color:var(--clr-gold)}
.cookie-btn--settings{background:transparent;color:var(--clr-text-dim);text-decoration:underline;border:none}
.cookie-btn--settings:hover{color:var(--clr-gold)}

/* Cookie Modal */
.cookie-modal-overlay{
  position:fixed;inset:0;z-index:9500;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;
}
.cookie-modal-overlay.visible{display:flex}
.cookie-modal{
  background:var(--clr-bg-card);border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);
  max-width:480px;width:90%;max-height:80vh;overflow-y:auto;
  padding:2.25rem;
}
.cookie-modal h3{font-size:var(--fs-lg);font-weight:700;margin-bottom:1.25rem;color:var(--clr-white)}
.cookie-category{
  display:flex;justify-content:space-between;align-items:center;
  padding:1rem 0;border-bottom:1px solid var(--clr-border);
}
.cookie-category-label{font-weight:600;font-size:var(--fs-sm);color:var(--clr-text)}
.cookie-category-desc{font-size:var(--fs-xs);color:var(--clr-text-dim)}
.cookie-toggle{position:relative;width:44px;height:24px;flex-shrink:0}
.cookie-toggle input{opacity:0;width:0;height:0;position:absolute}
.cookie-toggle-slider{
  position:absolute;inset:0;
  background:var(--clr-bg-elevated);border-radius:12px;
  cursor:pointer;transition:background .3s;
}
.cookie-toggle-slider::before{
  content:"";position:absolute;left:3px;top:3px;
  width:18px;height:18px;border-radius:50%;
  background:var(--clr-text-secondary);transition:transform .3s,background .3s;
}
.cookie-toggle input:checked+.cookie-toggle-slider{background:var(--clr-gold)}
.cookie-toggle input:checked+.cookie-toggle-slider::before{transform:translateX(20px);background:var(--clr-bg-deep)}
.cookie-toggle input:disabled+.cookie-toggle-slider{opacity:.5;cursor:not-allowed}
.cookie-modal-actions{margin-top:1.75rem;display:flex;gap:.6rem;justify-content:flex-end}
.cookie-modal-btn{
  padding:.6rem 1.35rem;border-radius:50px;
  font-size:var(--fs-sm);font-weight:600;border:none;
  transition:all var(--transition-smooth);
}
.cookie-modal-btn--save{
  background:linear-gradient(135deg, var(--clr-gold), var(--clr-gold-bright));
  color:var(--clr-bg-deep);
}
.cookie-modal-btn--save:hover{box-shadow:var(--shadow-glow-sm)}
.cookie-modal-btn--cancel{background:var(--clr-bg-elevated);color:var(--clr-text-secondary)}
.cookie-modal-btn--cancel:hover{color:var(--clr-text)}

/* ---------- Page Header (Sub Pages) ---------- */
.page-header{
  background:var(--clr-bg-surface);
  padding:calc(var(--header-h) + 3rem) 0 2.5rem;
  position:relative;overflow:hidden;
}
.page-header::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 400px 250px at 70% 60%, rgba(212,162,78,.06), transparent),
    radial-gradient(ellipse 300px 200px at 20% 40%, rgba(26,35,126,.1), transparent);
  pointer-events:none;
}
.page-header::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(212,162,78,.15), transparent);
}
.page-header h1{font-size:var(--fs-2xl);font-weight:900;color:var(--clr-white);position:relative;z-index:1;letter-spacing:-.02em}
.page-header p{color:var(--clr-text-secondary);margin-top:.5rem;position:relative;z-index:1}

/* ---------- Prose (legal pages) ---------- */
.prose{max-width:760px;padding:3.5rem 0}
.prose h2{font-size:var(--fs-xl);font-weight:700;margin:2.5rem 0 .85rem;color:var(--clr-white)}
.prose h3{font-size:var(--fs-lg);font-weight:600;margin:1.75rem 0 .6rem;color:var(--clr-text)}
.prose p{margin-bottom:1.15rem;color:var(--clr-text-secondary);line-height:1.85}
.prose ul,.prose ol{margin:0 0 1.15rem 1.25rem}
.prose ul{list-style:disc}
.prose ol{list-style:decimal}
.prose li{margin-bottom:.4rem;line-height:1.8;color:var(--clr-text-secondary)}
.prose li::marker{color:var(--clr-gold)}
.prose a{text-decoration:underline;text-underline-offset:3px}
.prose .table-wrap{overflow-x:auto;margin:1.25rem 0;-webkit-overflow-scrolling:touch}
.prose table{width:100%;border-collapse:collapse;min-width:420px}
.prose th,.prose td{text-align:left;padding:.7rem .9rem;border:1px solid var(--clr-border);font-size:var(--fs-sm);color:var(--clr-text-secondary)}
.prose th{background:var(--clr-bg-card);font-weight:600;color:var(--clr-text)}

/* ---------- Sitemap Page ---------- */
.sitemap-list{columns:2;gap:2.5rem}
.sitemap-list li{break-inside:avoid;margin-bottom:.6rem}
.sitemap-list a{font-size:var(--fs-md);display:inline-flex;align-items:center;gap:.4rem}

/* ---------- 404 ---------- */
.error-page{text-align:center;padding:calc(var(--header-h) + 4rem) 0 6rem}
.error-code{
  font-size:8rem;font-weight:900;line-height:1;
  background:linear-gradient(135deg, var(--clr-gold), var(--clr-magenta));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.error-page h1{font-size:var(--fs-2xl);margin:1.25rem 0 .75rem;color:var(--clr-white)}
.error-page p{color:var(--clr-text-secondary);margin-bottom:2.5rem}
.error-page a{
  display:inline-block;padding:.75rem 2rem;
  border-radius:50px;
  background:linear-gradient(135deg, var(--clr-gold), var(--clr-gold-bright));
  color:var(--clr-bg-deep);font-weight:700;
  transition:transform var(--transition-smooth),box-shadow var(--transition-smooth);
}
.error-page a:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow-md);color:var(--clr-bg-deep)}

/* ---------- Scroll Reveal Animations ---------- */
@media (prefers-reduced-motion: no-preference) {
  .reveal{
    opacity:0;
    transform:translateY(40px) scale(.97);
    filter:blur(3px);
    transition:opacity .7s ease,transform .7s ease,filter .7s ease;
    transition-delay:var(--reveal-delay,0ms);
  }
  .reveal.visible{
    opacity:1;
    transform:translateY(0) scale(1);
    filter:blur(0);
  }
  /* Directional reveals in two-col */
  .two-col>.reveal:first-child{transform:translateX(-35px);filter:blur(3px)}
  .two-col>.reveal:first-child.visible{transform:translateX(0);filter:blur(0)}
  .two-col>.reveal:last-child{transform:translateX(35px);filter:blur(3px)}
  .two-col>.reveal:last-child.visible{transform:translateX(0);filter:blur(0)}
}
@media (prefers-reduced-motion: reduce) {
  .reveal{opacity:1;transform:none;filter:none}
  *{animation-duration:0.01ms !important;transition-duration:0.01ms !important}
  body{opacity:1}
  .hero-inner>*{opacity:1;transform:none}
  .spotlight{animation:none !important}
}

/* ---------- Responsive ---------- */
@media (max-width:900px) {
  .two-col,.panel-tool-body{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .risk-grid{grid-template-columns:1fr}
  .hero{min-height:80vh}
  .hero h1{letter-spacing:-.02em}
}
@media (max-width:720px) {
  .cookie-inner{flex-direction:column;text-align:center}
  .cookie-actions{justify-content:center}
  .sitemap-list{columns:1}
  .section{padding:4rem 0}
}
