/* ============================================
   RAPIDA v54 — Shared CSS (aloldalak)
   Egységesen a főoldal stílusával
   ============================================ */
:root{
  --bg:           #f5f5f7;
  --bg-2:         #ebebee;
  --bg-elev:      #ffffff;
  --bg-subtle:    #fafafb;
  --bg-dark:      #0a0a0a;

  --ink:          #0a0a0a;
  --ink-2:        #1a1a1a;
  --ink-dim:      #525252;
  --ink-mute:     #8a8a8a;
  --ink-faint:    #d4d4d4;

  --accent:       #0a0a0a;
  --accent-deep:  #000000;
  --accent-soft:  #f4f4f2;
  --accent-line:  #e5e5e3;

  --gold:         #1e3a8a;
  --gold-deep:    #1e3a8a;
  --gold-soft:    #eff6ff;
  --gold-glow:    rgba(30,58,138,.18);

  --line:         rgba(10,10,10,.06);
  --line-2:       rgba(10,10,10,.03);
  --line-strong:  rgba(10,10,10,.12);

  --display:      'Inter', system-ui, sans-serif;
  --sans:         'Inter', system-ui, sans-serif;
  --serif:        'Inter', system-ui, sans-serif;
  /* Note: --serif retained for backward compat; brand now uses Inter italic 800 for accents */

  --maxw:         1240px;
  --maxw-narrow:  920px;

  --t-base:       180ms;
  --ease:         cubic-bezier(.4, 0, .2, 1);
  --ease-out:     cubic-bezier(.16, 1, .3, 1);

  --sh-1:         0 1px 2px rgba(10,10,10,.04);
  --sh-2:         0 4px 20px rgba(10,10,10,.06);
  --sh-3:         0 16px 50px rgba(10,10,10,.08);
}

/* DARK MODE — sötét téma változói */
[data-theme="dark"]{
  --bg:           #0a0a0a;
  --bg-2:         #141414;
  --bg-elev:      #161616;
  --bg-subtle:    #0d0d0d;
  --bg-dark:      #050505;

  --ink:          #fafafa;
  --ink-2:        #e5e5e5;
  --ink-dim:      #a3a3a3;
  --ink-mute:     #737373;
  --ink-faint:    #404040;

  --accent:       #fafafa;
  --accent-deep:  #ffffff;
  --accent-soft:  #1a1a1a;
  --accent-line:  #262626;

  --gold:         #1e3a8a;
  --gold-deep:    #1e3a8a;
  --gold-soft:    rgba(30,58,138,.12);
  --gold-glow:    rgba(30,58,138,.30);

  --line:         rgba(255,255,255,.08);
  --line-2:       rgba(255,255,255,.04);
  --line-strong:  rgba(255,255,255,.14);

  --sh-1:         0 1px 2px rgba(0,0,0,.30);
  --sh-2:         0 4px 20px rgba(0,0,0,.40);
  --sh-3:         0 16px 50px rgba(0,0,0,.50);
}

/* Theme toggle gomb */
.theme-toggle{
  width:38px;height:38px;
  border-radius:50%;
  background:transparent;
  border:1px solid var(--line-strong);
  display:grid;place-items:center;
  cursor:pointer;
  color:var(--ink-2);
  transition:border-color .25s var(--ease), transform .25s var(--ease-out), background .25s var(--ease);
  flex-shrink:0;
}
.theme-toggle:hover{
  border-color:var(--gold);
  background:var(--gold-soft);
  transform:scale(1.05);
}
.theme-toggle svg{
  width:18px;height:18px;
}
/* Specificitás: .theme-toggle .theme-icon-X (2 osztály) felülírja a .theme-toggle svg-t (1 osztály + elem) */
.theme-toggle .theme-icon-sun{display:none}
.theme-toggle .theme-icon-moon{display:block}
[data-theme="dark"] .theme-toggle .theme-icon-sun{display:block}
[data-theme="dark"] .theme-toggle .theme-icon-moon{display:none}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  min-height:100vh;
}

/* AMBIENT BACKGROUND */
.bg-layer{position:fixed;inset:0;pointer-events:none;z-index:0}
.bg-grad{
  position:absolute;inset:0;
  background:
    radial-gradient(70% 50% at 80% 0%, rgba(30,58,138,.05), transparent 60%),
    radial-gradient(60% 40% at 20% 100%, rgba(99,102,241,.04), transparent 60%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
}
[data-theme="dark"] .bg-grad{
  background:
    radial-gradient(80% 60% at 50% -10%, rgba(125,90,255,.04), transparent 60%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
}
.bg-grid{display:none}
.bg-noise{display:none}

/* PREMIUM AMBIENT GLOW — 3 lassan keringő orb (aloldalakra is) */
.bg-orb{
  position:absolute;
  border-radius:50%;
  pointer-events:none;
  filter:blur(80px);
  opacity:.35;
  will-change:transform;
}
.bg-orb-1{
  width:600px;height:600px;
  top:-15%;left:-10%;
  background:radial-gradient(circle, rgba(30,58,138,.55) 0%, rgba(30,58,138,0) 70%);
  animation:orbDrift1 22s ease-in-out infinite;
}
.bg-orb-2{
  width:500px;height:500px;
  top:30%;right:-15%;
  background:radial-gradient(circle, rgba(99,102,241,.45) 0%, rgba(99,102,241,0) 70%);
  animation:orbDrift2 28s ease-in-out infinite;
}
.bg-orb-3{
  width:550px;height:550px;
  bottom:-20%;left:30%;
  background:radial-gradient(circle, rgba(30,58,138,.45) 0%, rgba(30,58,138,0) 70%);
  animation:orbDrift3 32s ease-in-out infinite;
}
@keyframes orbDrift1{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(60px,80px) scale(1.1)}
  66%{transform:translate(-40px,40px) scale(.95)}
}
@keyframes orbDrift2{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-80px,60px) scale(1.15)}
}
@keyframes orbDrift3{
  0%,100%{transform:translate(0,0) scale(1)}
  40%{transform:translate(50px,-60px) scale(1.1)}
  80%{transform:translate(-30px,30px) scale(.95)}
}
.bg-orb-1{opacity:.32}
.bg-orb-2{opacity:.28}
.bg-orb-3{opacity:.30}
[data-theme="dark"] .bg-orb-1{opacity:.45}
[data-theme="dark"] .bg-orb-2{opacity:.38}
[data-theme="dark"] .bg-orb-3{opacity:.42}
@media (max-width:768px){
  .bg-orb{filter:blur(60px)}
  .bg-orb-1{width:400px;height:400px}
  .bg-orb-2{width:350px;height:350px}
  .bg-orb-3{width:380px;height:380px}
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:2}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:16px 0;transition:all .35s ease}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 22px;border-radius:100px;
  border:1px solid transparent;background:transparent;
  transition:all .35s ease;
}
.nav.scrolled .nav-inner,
.legal-page .nav .nav-inner,
.about-page .nav .nav-inner,
.contact-page .nav .nav-inner,
.auth-page-body .nav .nav-inner,
.dashboard-page-body .nav .nav-inner {
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(20px) saturate(150%);
  -webkit-backdrop-filter:blur(20px) saturate(150%);
  border-color:var(--line);
  box-shadow:0 8px 32px -12px rgba(10,10,10,.12);
}
[data-theme="dark"] .nav.scrolled .nav-inner,
[data-theme="dark"] .legal-page .nav .nav-inner,
[data-theme="dark"] .about-page .nav .nav-inner,
[data-theme="dark"] .contact-page .nav .nav-inner,
[data-theme="dark"] .auth-page-body .nav .nav-inner,
[data-theme="dark"] .dashboard-page-body .nav .nav-inner {
  background:rgba(15,15,15,.85);
  border-color:var(--line-strong);
  box-shadow:0 8px 32px -12px rgba(0,0,0,.4);
}
.logo{
  display:inline-flex;align-items:baseline;
  font-family:var(--display);font-weight:600;letter-spacing:-.025em;font-size:24px;
  color:var(--ink);text-decoration:none;
  line-height:1;
}
.logo-i{
  font-style:italic;font-weight:800;
  color:var(--gold-deep);
  font-size:1.05em;
  letter-spacing:-.02em;
}
.nav-links{display:flex;gap:28px;font-size:14px;font-weight:500}
.nav-links a{
  color:var(--ink-dim);text-decoration:none;
  transition:color var(--t-base) var(--ease);
}
.nav-links a:hover{color:var(--gold-deep)}
.nav-cta{display:flex;gap:10px;align-items:center}
@media (max-width:820px){.nav-links{display:none}}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 24px;border-radius:100px;
  font-family:var(--sans);font-weight:600;font-size:15px;
  text-decoration:none;border:none;cursor:pointer;
  transition:transform var(--t-base) var(--ease-out),
             box-shadow var(--t-base) var(--ease),
             background var(--t-base) var(--ease),
             border-color var(--t-base) var(--ease);
}
.btn-primary{
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  color:#fff;
  box-shadow:0 4px 14px rgba(30,58,138,.28), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(30,58,138,.40), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-ghost{
  background:transparent;color:var(--ink);
  border:1px solid var(--line-strong);
}
.btn-ghost:hover{background:var(--bg-elev);border-color:var(--gold);color:var(--gold-deep)}

.sec-label{
  font-family:var(--sans);font-size:12.5px;letter-spacing:0;
  color:var(--ink-2);margin-bottom:24px;
  display:inline-flex;align-items:center;gap:12px;
  font-weight:500;
}
.sec-label::before{content:"";width:32px;height:1px;background:var(--gold)}

/* LEGAL / ABOUT / CONTACT */
main.legal,
main.about,
main.contact,
main.auth-page,
main.dash-page{
  padding:160px 0 100px;
  position:relative;z-index:2;
}

.legal-header,
.about-header,
.contact-header{
  max-width:820px;margin:0 auto 64px;
  text-align:left;
}
.legal-header h1,
.about-header h1,
.contact-header h1{
  font-family:var(--display);font-weight:800;
  font-size:clamp(40px, 6vw, 72px);
  line-height:1.02;letter-spacing:-.032em;
  margin:18px 0 20px;color:var(--ink);
}
.legal-header h1 .italic,
.about-header h1 .italic,
.contact-header h1 .italic{
  font-style:italic;font-weight:800;color:var(--gold-deep);
}
.legal-meta{font-size:14.5px;color:var(--ink-mute)}
.legal-meta strong{color:var(--ink-2);font-weight:600}

/* TOC */
.legal-toc{
  max-width:820px;margin:0 auto 64px;
  padding:32px 36px;
  background:var(--bg-elev);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--sh-1);
}
.legal-toc-title{
  font-family:var(--display);font-weight:600;font-size:14px;
  color:var(--ink);margin-bottom:18px;
  display:flex;align-items:center;gap:10px;
}
.legal-toc-title::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
}
.legal-toc ol{
  list-style:none;
  display:grid;grid-template-columns:repeat(2, 1fr);
  gap:10px 32px;
  counter-reset:toc;
}
@media (max-width:600px){.legal-toc ol{grid-template-columns:1fr}}
.legal-toc li{
  counter-increment:toc;
  font-size:14.5px;
  display:flex;align-items:baseline;gap:10px;
}
.legal-toc li::before{
  content:counter(toc, decimal-leading-zero);
  font-family:var(--sans);font-size:11.5px;
  color:var(--gold-deep);font-weight:600;flex-shrink:0;
  letter-spacing:.02em;
}
.legal-toc a{
  color:var(--ink-dim);text-decoration:none;
  transition:color var(--t-base) var(--ease);
}
.legal-toc a:hover{color:var(--gold-deep)}

/* CONTENT — minden szekció kártyában */
.legal-content,
.about-content,
.contact-content{
  max-width:820px;margin:0 auto;
}

.legal-content section,
.about-content section{
  margin-bottom:20px;
  scroll-margin-top:100px;
  padding:40px 44px;
  background:var(--bg-elev);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--sh-1);
  transition:transform var(--t-base) var(--ease-out),
             box-shadow var(--t-base) var(--ease);
}
.legal-content section:hover,
.about-content section:hover{
  transform:translateY(-2px);
  box-shadow:var(--sh-2);
}

.legal-content h2,
.about-content h2{
  font-family:var(--display);font-weight:600;
  font-size:24px;letter-spacing:-.018em;
  margin-bottom:20px;color:var(--ink);
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.legal-content h3,
.about-content h3{
  font-family:var(--display);font-weight:600;
  font-size:18px;letter-spacing:-.012em;
  margin:28px 0 12px;color:var(--ink);
}
.legal-content p,
.about-content p{
  font-size:15.5px;line-height:1.7;
  color:var(--ink-dim);
  margin-bottom:14px;
}
.legal-content p strong,
.about-content p strong{color:var(--ink);font-weight:600}
.legal-content ul,
.about-content ul{
  margin:14px 0 18px 22px;
  font-size:15.5px;line-height:1.7;color:var(--ink-dim);
}
.legal-content li{margin-bottom:8px}
.legal-content li::marker{color:var(--gold)}
.legal-content a,
.about-content a{
  color:var(--gold-deep);
  text-decoration:underline;
  text-decoration-color:var(--gold-soft);
  text-underline-offset:2px;
  transition:text-decoration-color var(--t-base) var(--ease);
}
.legal-content a:hover,
.about-content a:hover{text-decoration-color:var(--gold)}

/* Highlighted info-box */
.legal-info-box{
  margin:24px 0;padding:22px 24px;
  background:var(--gold-soft);
  border:1px solid rgba(30,58,138,.20);
  border-radius:16px;
  font-size:14.5px;color:var(--ink-2);line-height:1.6;
}
.legal-info-box strong{color:var(--ink);display:block;margin-bottom:6px;font-weight:600}

/* Footer-CTA — Selligence sötét kártya */
.legal-footer-cta,
.about-footer-cta{
  max-width:820px;margin:80px auto 0;
  padding:40px 44px;
  background:linear-gradient(135deg, var(--ink) 0%, #1a1a1a 100%);
  border-radius:28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  box-shadow:0 24px 60px -16px rgba(10,10,10,.25);
  position:relative;overflow:hidden;
}
.legal-footer-cta::before,
.about-footer-cta::before{
  content:'';position:absolute;
  top:-50%;right:-20%;width:80%;height:200%;
  background:radial-gradient(circle, rgba(30,58,138,.18), transparent 70%);
  pointer-events:none;
}
.legal-footer-cta p,
.about-footer-cta p{
  font-family:var(--display);font-weight:500;font-size:20px;
  color:#fff;letter-spacing:-.01em;
  position:relative;z-index:2;
}
.legal-footer-cta .btn,
.about-footer-cta .btn{position:relative;z-index:2}

/* Footer-CTA dark mode - kék gradient hogy elváljon a fekete bodytól */
[data-theme="dark"] .legal-footer-cta,
[data-theme="dark"] .about-footer-cta{
  background:linear-gradient(135deg, #1a1a2e 0%, #0f1729 100%);
  border:1px solid var(--line-strong);
  box-shadow:0 24px 60px -16px rgba(0,0,0,.5);
}
[data-theme="dark"] .legal-footer-cta::before,
[data-theme="dark"] .about-footer-cta::before{
  background:radial-gradient(circle, rgba(30,58,138,.30), transparent 70%);
}

@media (max-width:680px){
  .legal-footer-cta,
  .about-footer-cta{flex-direction:column;align-items:flex-start;padding:32px}
  .legal-footer-cta p,
  .about-footer-cta p{font-size:18px}
}

/* FOOTER — régi alap stílus eltávolítva, az új gazdag footer a fájl végén */

::selection{background:var(--gold-soft);color:var(--ink)}

/* MOBIL — átfogó */
@media (max-width:768px){
  .wrap{padding:0 20px}
  main.legal,main.about,main.contact,main.auth-page,main.dash-page{padding:110px 0 60px}

  /* Headerek */
  .legal-header,.about-header,.contact-header{margin-bottom:36px}
  .legal-header h1,
  .about-header h1,
  .contact-header h1{font-size:36px;line-height:1.05;letter-spacing:-.025em;margin:14px 0 16px}
  .legal-meta{font-size:13.5px}
  .sec-label{font-size:11.5px;margin-bottom:18px}

  /* Kártyák */
  .legal-content section,
  .about-content section{padding:28px 24px;margin-bottom:14px;border-radius:20px}
  .legal-content h2,
  .about-content h2{font-size:20px;letter-spacing:-.012em;margin-bottom:16px;padding-bottom:12px}
  .legal-content h3,
  .about-content h3{font-size:16px;margin:22px 0 10px}
  .legal-content p,
  .about-content p{font-size:14.5px;line-height:1.65;margin-bottom:12px}
  .legal-content ul,
  .about-content ul{font-size:14.5px;line-height:1.65;margin:12px 0 16px 20px}

  /* TOC */
  .legal-toc{padding:24px;margin-bottom:36px;border-radius:20px}
  .legal-toc-title{font-size:13px;margin-bottom:14px}
  .legal-toc li{font-size:13.5px}

  /* Info-box */
  .legal-info-box{padding:18px 20px;border-radius:14px;font-size:13.5px}

  /* Footer-CTA */
  .legal-footer-cta,
  .about-footer-cta{padding:32px 28px;margin-top:60px;border-radius:24px}
  .legal-footer-cta p,
  .about-footer-cta p{font-size:18px}

  /* About-specific */
  .about-hero{margin-bottom:48px;gap:40px}
  .about-hero-visual{aspect-ratio:1.2/1;border-radius:24px;max-height:280px}
  .about-monogram{font-size:160px}
  .about-values{gap:14px;margin:60px auto}
  .value-card{padding:28px 24px;border-radius:20px}
  .value-card h3{font-size:17px}
  .value-card p{font-size:13.5px}
  .value-icon{width:46px;height:46px;margin-bottom:18px}
  .value-num{font-size:10.5px;margin-bottom:10px}

  /* Contact-specific */
  .contact-form{padding:28px 22px;border-radius:24px}
  .contact-form h2{font-size:20px;margin-bottom:6px}
  .contact-form .desc{font-size:13.5px;margin-bottom:22px}
  .form-field{margin-bottom:14px}
  .form-field label{font-size:12.5px;margin-bottom:6px}
  .form-field input,
  .form-field textarea,
  .form-field select{padding:11px 14px;font-size:14px}
  .form-field textarea{min-height:110px}
  .form-checkbox{font-size:12.5px;margin:18px 0;gap:10px}
  .form-submit{padding:13px;font-size:14px}
  .form-success{padding:16px 18px;border-radius:14px}
  .form-success-icon{width:32px;height:32px}
  .form-success strong{font-size:14px}
  .form-success p{font-size:12.5px}
  .contact-card{padding:22px;border-radius:20px}
  .contact-card-icon{width:38px;height:38px;margin-bottom:12px}
  .contact-card h3{font-size:14.5px;margin-bottom:6px}
  .contact-card p{font-size:13px}

  /* Nav mobil */
  .nav{padding:12px 0}
  .nav-inner{padding:8px 14px}
  .logo{font-size:20px}
  .btn{padding:11px 18px;font-size:14px}

  /* Footer */
  footer{padding:40px 0 32px;margin-top:60px}
  .footer-inner{flex-direction:column;align-items:flex-start;gap:14px}
  .footer-inner p{font-size:12.5px}
  .footer-links{gap:18px;flex-wrap:wrap}
  .footer-links a{font-size:12.5px}
}

/* Kicsi mobile (≤480px) */
@media (max-width:480px){
  .wrap{padding:0 16px}
  .nav{padding:10px 0}
  .nav-inner{padding:7px 12px}
  .logo{font-size:18px}

  main.legal,main.about,main.contact,main.auth-page,main.dash-page{padding:96px 0 48px}

  /* Headerek kompaktabb */
  .legal-header h1,
  .about-header h1,
  .contact-header h1{font-size:30px;line-height:1.08}

  /* Kártyák kompaktabb */
  .legal-content section,
  .about-content section{padding:22px 18px;margin-bottom:12px;border-radius:18px}
  .legal-content h2,
  .about-content h2{font-size:18px}
  .legal-content p,
  .about-content p{font-size:14px}

  /* TOC */
  .legal-toc{padding:20px;border-radius:18px}

  /* Footer CTA */
  .legal-footer-cta,
  .about-footer-cta{padding:26px 22px;border-radius:20px}
  .legal-footer-cta p,
  .about-footer-cta p{font-size:16px}
  .legal-footer-cta .btn,
  .about-footer-cta .btn{width:100%;justify-content:center}

  /* About */
  .about-monogram{font-size:120px}
  .about-values{margin:48px auto}

  /* Contact form */
  .contact-form{padding:24px 18px;border-radius:20px}
  .contact-card{padding:18px;border-radius:18px}
}

/* Nagyon kicsi (≤360px) */
@media (max-width:360px){
  .legal-header h1,
  .about-header h1,
  .contact-header h1{font-size:28px}
  .legal-content h2,
  .about-content h2{font-size:17px}
  .legal-content section,
  .about-content section{padding:20px 16px}
}

/* ABOUT-specific */
.about-hero{
  display:grid;grid-template-columns:1.2fr 1fr;
  gap:80px;align-items:center;
  max-width:1100px;margin:0 auto 100px;
}
@media (max-width:900px){.about-hero{grid-template-columns:1fr;gap:48px;margin-bottom:60px}}
.about-hero-visual{
  aspect-ratio:1/1;
  background:var(--bg-elev);
  border:1px solid var(--line);
  border-radius:32px;
  position:relative;overflow:hidden;
  box-shadow:var(--sh-3);
  display:grid;place-items:center;
}
.about-hero-visual::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 30%, rgba(30,58,138,.20), transparent 50%),
    radial-gradient(circle at 70% 70%, rgba(30,58,138,.08), transparent 50%);
}
.about-monogram{
  font-style:italic;font-weight:800;
  font-size:clamp(140px, 22vw, 240px);
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  line-height:1;letter-spacing:-.02em;
  position:relative;z-index:2;
}

.about-values{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:20px;
  max-width:1100px;margin:80px auto;
}
@media (max-width:820px){.about-values{grid-template-columns:1fr}}
.value-card{
  padding:36px 32px;
  background:var(--bg-elev);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--sh-1);
  transition:transform var(--t-base) var(--ease-out),
             box-shadow var(--t-base) var(--ease);
  position:relative;overflow:hidden;
}
.value-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--sh-3);
}
.value-card::before{
  content:"";position:absolute;top:0;left:20%;right:20%;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:0;transition:opacity .4s var(--ease-out);
}
.value-card:hover::before{opacity:1}
.value-icon{
  width:52px;height:52px;border-radius:50%;
  background:var(--gold-soft);
  color:var(--gold-deep);
  display:grid;place-items:center;
  margin-bottom:24px;
  transition:transform .3s var(--ease-out);
}
.value-card:hover .value-icon{transform:scale(1.08) rotate(-3deg)}
.value-icon svg{width:22px;height:22px}
.value-num{
  font-family:var(--sans);font-size:11px;
  color:var(--gold-deep);margin-bottom:12px;
  letter-spacing:.04em;font-weight:600;
  text-transform:uppercase;
  display:block;
}
.value-card h3{
  font-family:var(--display);font-weight:600;font-size:20px;
  letter-spacing:-.015em;color:var(--ink);margin-bottom:10px;
  line-height:1.3;
}
.value-card p{font-size:14.5px;color:var(--ink-dim);line-height:1.6}

/* CONTACT-specific */
.contact-grid{
  display:grid;grid-template-columns:1.3fr 1fr;
  gap:32px;
  max-width:1100px;margin:0 auto;
}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr;gap:24px}}

.contact-form{
  padding:40px 36px;
  background:var(--bg-elev);
  border:1px solid var(--line);
  border-radius:28px;
  box-shadow:var(--sh-2);
}
.contact-form h2{
  font-family:var(--display);font-weight:600;
  font-size:24px;letter-spacing:-.018em;
  margin-bottom:8px;color:var(--ink);
}
.contact-form .desc{
  color:var(--ink-dim);font-size:15px;margin-bottom:28px;line-height:1.6;
}
.form-row{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}
.form-field{margin-bottom:18px}
.form-field label{
  display:block;
  font-size:13px;font-weight:500;color:var(--ink-2);
  margin-bottom:7px;
}
.form-field input,
.form-field textarea,
.form-field select{
  width:100%;
  padding:13px 16px;
  background:var(--bg-subtle);
  border:1px solid var(--line);
  border-radius:12px;
  font-family:var(--sans);font-size:14.5px;color:var(--ink);
  outline:none;
  transition:border-color var(--t-base) var(--ease),
             box-shadow var(--t-base) var(--ease),
             background var(--t-base) var(--ease);
}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus{
  border-color:var(--gold);
  background:var(--bg-elev);
  box-shadow:0 0 0 4px var(--gold-glow);
}
.form-field textarea{resize:vertical;min-height:130px;font-family:var(--sans);line-height:1.55}
.form-checkbox{
  display:flex;align-items:flex-start;gap:12px;margin:20px 0;
  font-size:13.5px;color:var(--ink-dim);line-height:1.55;
}
.form-checkbox input{width:18px;height:18px;flex-shrink:0;margin-top:2px;accent-color:var(--gold)}
.form-checkbox a{color:var(--gold-deep);text-decoration:underline;text-decoration-color:var(--gold-soft)}
.form-submit{
  width:100%;justify-content:center;padding:15px;
  margin-top:8px;
}

.form-success{
  display:none;
  margin-top:18px;padding:20px 22px;
  background:var(--gold-soft);
  border:1px solid rgba(30,58,138,.20);
  border-radius:16px;
  align-items:center;gap:14px;
}
.form-success.show{display:flex}
.form-success-icon{
  width:38px;height:38px;flex-shrink:0;
  border-radius:50%;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  color:#fff;
  display:grid;place-items:center;
  box-shadow:0 4px 12px var(--gold-glow);
}
.form-success strong{
  display:block;font-family:var(--display);font-weight:600;color:var(--ink);
  margin-bottom:3px;font-size:15px;
}
.form-success p{font-size:13px;color:var(--ink-dim)}

.contact-info{
  display:flex;flex-direction:column;gap:16px;
}
.contact-card{
  padding:28px;
  background:var(--bg-elev);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--sh-1);
  transition:transform var(--t-base) var(--ease-out),
             box-shadow var(--t-base) var(--ease);
}
.contact-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--sh-2);
}
.contact-card-icon{
  width:44px;height:44px;border-radius:50%;
  background:var(--gold-soft);color:var(--gold-deep);
  display:grid;place-items:center;margin-bottom:16px;
}
.contact-card-icon svg{width:20px;height:20px}
.contact-card h3{
  font-family:var(--display);font-weight:600;font-size:16px;
  margin-bottom:8px;color:var(--ink);letter-spacing:-.01em;
}
.contact-card p{
  font-size:14px;color:var(--ink-dim);line-height:1.6;
}
.contact-card a{
  color:var(--gold-deep);text-decoration:underline;
  text-decoration-color:var(--gold-soft);
  font-weight:500;
  transition:text-decoration-color var(--t-base) var(--ease);
}
.contact-card a:hover{text-decoration-color:var(--gold)}

/* ============================================
   COOKIE BANNER
   ============================================ */
.cookie-banner{
  position:fixed;bottom:20px;left:20px;right:20px;
  z-index:90;
  max-width:560px;margin:0 auto;
  padding:20px 24px;
  background:var(--bg-elev);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:0 24px 60px -10px rgba(10,10,10,.18), var(--sh-2);
  display:none;
  align-items:center;gap:16px;
  animation:cookieIn .4s var(--ease-out);
}
.cookie-banner.show{display:flex}
@keyframes cookieIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.cookie-icon{
  width:40px;height:40px;flex-shrink:0;
  border-radius:50%;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  color:#fff;
  display:grid;place-items:center;
  box-shadow:0 4px 12px var(--gold-glow);
}
.cookie-text{flex:1;font-size:13.5px;color:var(--ink-dim);line-height:1.55}
.cookie-text strong{color:var(--ink);font-weight:600}
.cookie-text a{color:var(--gold-deep);text-decoration:underline;text-decoration-color:var(--gold-soft);text-underline-offset:2px}
.cookie-actions{display:flex;gap:8px;flex-shrink:0}
.cookie-actions button{
  padding:9px 18px;border-radius:100px;
  font-family:var(--sans);font-weight:500;font-size:13px;
  cursor:pointer;border:none;
  transition:all var(--t-base) var(--ease);
}
.cookie-decline{
  background:transparent;color:var(--ink-dim);
  border:1px solid var(--line-strong);
}
.cookie-decline:hover{background:var(--bg-2);border-color:var(--ink-dim)}
.cookie-accept{
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  color:#fff;
  box-shadow:0 4px 12px var(--gold-glow);
}
.cookie-accept:hover{box-shadow:0 8px 20px rgba(30,58,138,.35)}
@media (max-width:560px){
  .cookie-banner{flex-direction:column;align-items:flex-start;left:12px;right:12px;bottom:12px;padding:18px;border-radius:20px}
  .cookie-actions{width:100%}
  .cookie-actions button{flex:1}
}

/* ============================================
   RICH FOOTER — egységes a főoldallal
   ============================================ */
footer{padding:80px 0 32px;border-top:1px solid var(--line);position:relative}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:48px;
}
.footer-col{display:flex;flex-direction:column;gap:10px}
.footer-logo{
  font-family:var(--display);font-weight:600;font-size:22px;
  letter-spacing:-.025em;color:var(--ink);
  margin-bottom:6px;
}
.footer-tagline{font-size:13.5px;color:var(--ink-dim);line-height:1.55;max-width:300px}
.footer-h{
  font-family:var(--display);font-weight:600;font-size:13px;
  color:var(--ink);
  letter-spacing:-.005em;
  margin-bottom:6px;
  text-transform:uppercase;
}
.footer-link, .footer-contact-link{
  font-size:13.5px;color:var(--ink-dim);
  text-decoration:none;
  transition:color var(--t-base) var(--ease);
  display:inline-flex;align-items:center;gap:8px;
}
.footer-link:hover, .footer-contact-link:hover{color:var(--gold)}
.footer-contact-link svg{flex-shrink:0;color:var(--gold);opacity:.8}
.footer-address, .footer-tax{
  font-size:12.5px;color:var(--ink-mute);
  margin-top:4px;
}
.footer-bottom{
  padding-top:28px;
  border-top:1px solid var(--line);
  text-align:center;
}
.footer-bottom p{font-size:12.5px;color:var(--ink-mute)}

@media (max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px 24px;margin-bottom:36px}
  .footer-col:first-child{grid-column:1 / -1}
  .footer-tagline{max-width:none}
}
