@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --bg:#FAFAF7; --bg-warm:#F4EFE6; --bg-dark:#141C18; --bg-dark2:#1C2820;
  --accent:#2D6A4F; --accent-h:#3D8B68; --accent-light:rgba(45,106,79,.1);
  --gold:#C49A3C;
  --text:#141C18; --text2:#4A5A50; --text3:#8A9A8C; --text-inv:#F4EFE6;
  --border:#E0D9CE; --border-l:#EDE8E0;
  --danger:#C0392B; --warn:#D4883A; --ok:#2D6A4F;
  --serif:'Playfair Display',Georgia,serif; --sans:'DM Sans',system-ui,sans-serif;
  --r:12px; --rl:20px;
  --sh:0 4px 24px rgba(20,28,24,.07); --sh2:0 12px 48px rgba(20,28,24,.12);
  --max:1200px; --nav:72px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--accent);color:#fff}

@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes pageIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.page-wrap{animation:pageIn .35s ease both}

/* ── NAV ── */
.nav{position:sticky;top:0;z-index:200;background:rgba(20,28,24,.97);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.06);height:var(--nav)}
.nav-in{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:100%}
.nav-logo{display:flex;align-items:center;gap:11px;text-decoration:none;cursor:pointer}
.nav-logo-icon{width:38px;height:38px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:#fff;transition:transform .3s;font-family:var(--serif)}
.nav-logo:hover .nav-logo-icon{transform:rotate(-8deg) scale(1.08)}
.nav-logo-name{font-family:var(--serif);font-size:1.15rem;font-weight:600;color:var(--text-inv)}
.nav-logo-name b{color:var(--gold)}
.nav-center{display:flex;align-items:center;gap:2px}
.nav-item{position:relative}
.nav-link{background:none;border:none;color:rgba(244,239,230,.7);font-family:var(--sans);font-size:.875rem;font-weight:500;padding:8px 14px;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px;white-space:nowrap;text-decoration:none}
.nav-link:hover,.nav-link.active{color:var(--text-inv);background:rgba(255,255,255,.08)}
.nav-link svg{width:14px;height:14px;transition:transform .2s}
.nav-item:hover .nav-link svg{transform:rotate(180deg)}
.mega-drop{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(-8px);background:#1a2520;border:1px solid rgba(255,255,255,.1);border-radius:var(--rl);box-shadow:var(--sh2);padding:12px 20px 20px;min-width:500px;opacity:0;visibility:hidden;transition:all .2s;pointer-events:none}
.nav-item:hover .mega-drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:all}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.mega-item{display:flex;align-items:flex-start;gap:12px;padding:11px 13px;border-radius:10px;cursor:pointer;transition:background .2s;text-decoration:none}
.mega-item:hover{background:rgba(255,255,255,.06)}
.mega-icon{font-size:1.3rem;flex-shrink:0;margin-top:1px}
.mega-item-title{font-size:.85rem;font-weight:600;color:var(--text-inv);margin-bottom:2px}
.mega-item-sub{font-size:.72rem;color:rgba(244,239,230,.4);line-height:1.4}
.cert-col-title{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);padding:8px 13px 4px}
.cert-link{display:block;padding:7px 13px;border-radius:8px;font-size:.83rem;color:rgba(244,239,230,.7);cursor:pointer;transition:all .2s;text-decoration:none}
.cert-link:hover{background:rgba(255,255,255,.06);color:var(--text-inv)}
.nav-right{display:flex;align-items:center;gap:10px}
.btn-ghost{background:none;border:1px solid rgba(255,255,255,.2);color:rgba(244,239,230,.8);font-family:var(--sans);font-size:.875rem;font-weight:500;padding:8px 18px;border-radius:8px;cursor:pointer;transition:all .2s;text-decoration:none}
.btn-ghost:hover{background:rgba(255,255,255,.08);color:var(--text-inv)}
.btn-cta{background:var(--accent);color:#fff;font-family:var(--sans);font-size:.875rem;font-weight:600;padding:9px 22px;border-radius:8px;border:none;cursor:pointer;transition:all .2s;text-decoration:none}
.btn-cta:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:0 6px 20px rgba(45,106,79,.35)}
.mob-tog{display:none;background:none;border:none;color:var(--text-inv);cursor:pointer;padding:4px}
.mob-menu{display:none;position:fixed;inset:0;top:var(--nav);background:rgba(20,28,24,.98);z-index:150;padding:20px;flex-direction:column;gap:4px;overflow-y:auto}
.mob-menu.open{display:flex}
.mob-link{display:block;padding:13px 14px;border-radius:10px;color:rgba(244,239,230,.8);font-size:.95rem;font-weight:500;text-decoration:none;transition:all .15s}
.mob-link:hover{background:rgba(255,255,255,.07);color:#fff}

/* ── BREADCRUMB ── */
.breadcrumb{background:var(--bg-warm);border-bottom:1px solid var(--border);padding:10px 32px}
.breadcrumb-in{max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text3)}
.breadcrumb a{color:var(--accent);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}

/* ── LAYOUT ── */
.sec{max-width:var(--max);margin:0 auto;padding:80px 32px}
.sec-label{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.sec-title{font-family:var(--serif);font-size:clamp(1.9rem,3vw,2.6rem);font-weight:700;line-height:1.12;letter-spacing:-.025em;margin-bottom:14px}
.sec-sub{font-size:1.05rem;color:var(--text2);max-width:580px;line-height:1.7}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-size:.95rem;font-weight:600;padding:13px 28px;border-radius:var(--r);border:none;cursor:pointer;transition:all .25s;text-decoration:none}
.btn-p{background:var(--accent);color:#fff}
.btn-p:hover{background:var(--accent-h);transform:translateY(-2px);box-shadow:0 10px 32px rgba(45,106,79,.3)}
.btn-s{background:rgba(255,255,255,.07);color:var(--text-inv);border:1px solid rgba(255,255,255,.15)}
.btn-s:hover{background:rgba(255,255,255,.12)}
.btn-o{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}
.btn-o:hover{background:var(--accent-light)}
.btn-sm{padding:9px 18px;font-size:.85rem}

/* ── HERO ── */
.hero{background:var(--bg-dark);padding:90px 32px 72px;position:relative;overflow:hidden;color:var(--text-inv)}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 15% 60%,rgba(45,106,79,.18),transparent 65%),radial-gradient(ellipse 50% 70% at 85% 20%,rgba(196,154,60,.1),transparent 60%);pointer-events:none}
.hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.hero-in{max-width:var(--max);margin:0 auto;position:relative;z-index:1}
.hero-in.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:50px;padding:6px 16px;margin-bottom:22px;font-size:.75rem;font-weight:600;color:var(--gold);letter-spacing:.05em;text-transform:uppercase;animation:fadeUp .5s ease both}
.hero-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;animation:pulse 2s ease infinite;display:inline-block}
.hero h1{font-family:var(--serif);font-size:clamp(2.2rem,4vw,3.2rem);font-weight:700;line-height:1.08;letter-spacing:-.025em;color:#fff;margin-bottom:18px;animation:fadeUp .5s .1s ease both}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero-sub{font-size:1rem;line-height:1.72;color:rgba(244,239,230,.65);margin-bottom:28px;max-width:480px;animation:fadeUp .5s .15s ease both}
.hero-checks{list-style:none;margin-bottom:32px;animation:fadeUp .5s .2s ease both}
.hero-checks li{display:flex;align-items:center;gap:9px;padding:4px 0;font-size:.92rem;color:rgba(244,239,230,.8)}
.hero-check{color:var(--accent-h);font-weight:700}
.hero-acts{display:flex;gap:12px;flex-wrap:wrap;animation:fadeUp .5s .25s ease both}
.trust-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:24px;animation:fadeUp .5s .3s ease both}
.trust-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:50px;padding:5px 12px;font-size:.75rem;font-weight:500;color:rgba(244,239,230,.75)}
.trust-badge .ck{color:var(--accent-h)}

/* Page hero (subpages) */
.page-hero{background:var(--bg-dark);padding:60px 32px 52px;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 100% at 10% 50%,rgba(45,106,79,.15),transparent 60%)}
.page-hero-in{max-width:var(--max);margin:0 auto;position:relative;z-index:1}
.page-hero h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:700;color:#fff;margin-bottom:12px;letter-spacing:-.02em}
.page-hero p{font-size:1.05rem;color:rgba(244,239,230,.65);max-width:520px;line-height:1.65}

/* ── CARDS ── */
.card{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:28px;transition:all .25s}
.card:hover{box-shadow:var(--sh);transform:translateY(-2px)}

.cert-card{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:26px;cursor:pointer;transition:all .25s;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.cert-card:hover{border-color:rgba(45,106,79,.3);box-shadow:var(--sh);transform:translateY(-2px)}
.cert-card.featured{border-color:var(--accent);background:linear-gradient(135deg,#fff 0%,rgba(45,106,79,.03) 100%)}
.cert-cat{font-size:.68rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text3);background:var(--bg-warm);padding:3px 9px;border-radius:50px}
.cert-card h3{font-family:var(--serif);font-size:1.1rem;font-weight:600;margin:10px 0 7px}
.cert-card p{font-size:.855rem;color:var(--text2);line-height:1.55;flex:1}
.cert-meta{display:flex;gap:14px;flex-wrap:wrap;margin-top:16px;padding-top:14px;border-top:1px solid var(--border-l)}
.cert-mi{font-size:.75rem;color:var(--text3)}
.cert-price{margin-left:auto;font-size:1.1rem;font-weight:700;color:var(--accent);font-family:var(--serif)}

.branche-card{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:26px 20px;cursor:pointer;transition:all .25s;text-align:center;text-decoration:none;display:block}
.branche-card:hover{border-color:var(--accent);box-shadow:var(--sh);transform:translateY(-3px)}
.branche-icon{font-size:2.2rem;margin-bottom:12px;display:block}
.branche-name{font-family:var(--serif);font-size:1rem;font-weight:600;color:var(--text);margin-bottom:5px}
.branche-certs{font-size:.74rem;color:var(--text3);line-height:1.6}
.branche-tag{display:inline-block;margin-top:10px;background:var(--accent-light);color:var(--accent);font-size:.68rem;font-weight:600;padding:3px 10px;border-radius:50px}

.step-card{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:28px;text-align:center;transition:all .25s}
.step-card:hover{box-shadow:var(--sh);transform:translateY(-3px)}
.step-num{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;font-family:var(--serif);font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.step-card h3{font-family:var(--serif);font-size:1.05rem;font-weight:600;margin-bottom:8px}
.step-card p{font-size:.855rem;color:var(--text2);line-height:1.6}
.step-sub{font-size:.74rem;color:var(--text3);margin-top:10px;padding-top:10px;border-top:1px solid var(--border-l)}

.price-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--rl);padding:32px 28px;position:relative;transition:all .25s}
.price-card.featured{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--sh2)}
.price-card.featured::before{content:'Beliebteste Wahl';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:.68rem;font-weight:700;padding:3px 14px;border-radius:50px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
.price-card h3{font-family:var(--serif);font-size:1.2rem;font-weight:600;margin-bottom:4px}
.price-amount{font-family:var(--serif);font-size:2.2rem;font-weight:700;color:var(--accent);margin:12px 0 4px}
.price-amount span{font-size:.9rem;font-weight:400;color:var(--text3)}
.price-note{font-size:.8rem;color:var(--text3);margin-bottom:20px}
.price-features{list-style:none;margin:0 0 24px}
.price-features li{font-size:.855rem;color:var(--text2);padding:6px 0 6px 22px;position:relative;border-bottom:1px solid var(--border-l)}
.price-features li:last-child{border-bottom:none}
.price-features li::before{content:'✓';position:absolute;left:0;color:var(--accent);font-weight:700}
.btn-price{width:100%;padding:12px;border-radius:var(--r);font-family:var(--sans);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;text-decoration:none;display:block;text-align:center}
.btn-price.p{background:var(--accent);color:#fff}
.btn-price.p:hover{background:var(--accent-h)}
.btn-price.o{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}
.btn-price.o:hover{background:var(--accent-light)}

.testi-card{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:26px}
.testi-stars{color:var(--gold);font-size:.88rem;margin-bottom:10px}
.testi-text{font-size:.875rem;color:var(--text2);line-height:1.65;font-style:italic;margin-bottom:14px}
.testi-author{font-size:.8rem;font-weight:600;color:var(--text)}
.testi-role{font-size:.76rem;color:var(--text3);margin-top:2px}

/* ── GRIDS ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}

/* ── MISC ── */
.stats-bar{background:var(--bg-dark2);border-bottom:1px solid rgba(255,255,255,.06)}
.stats-bar-in{max-width:var(--max);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:26px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.06)}
.stat-item:last-child{border-right:none}
.stat-n{font-family:var(--serif);font-size:2rem;font-weight:700;color:var(--gold)}
.stat-l{font-size:.8rem;color:rgba(244,239,230,.5);margin-top:3px}

.filter-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:28px 0}
.filter-tab{background:none;border:1.5px solid var(--border);color:var(--text2);font-family:var(--sans);font-size:.82rem;font-weight:500;padding:7px 18px;border-radius:50px;cursor:pointer;transition:all .2s}
.filter-tab:hover{border-color:var(--accent);color:var(--text)}
.filter-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}

.prob-card{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:28px}
.prob-card.sol{border-color:var(--accent);background:rgba(45,106,79,.03)}
.prob-item{display:flex;gap:12px;margin-bottom:12px;font-size:.875rem;color:var(--text2);line-height:1.6}

.highlight-box{background:rgba(45,106,79,.08);border:1px solid rgba(45,106,79,.25);border-radius:var(--rl);padding:22px 26px;margin:20px 0}
.highlight-box h4{font-family:var(--serif);font-size:1rem;font-weight:600;color:var(--accent);margin-bottom:6px}
.highlight-box p{font-size:.875rem;color:var(--text2);line-height:1.65}

.alert-box{background:rgba(192,57,43,.08);border:1px solid rgba(192,57,43,.2);border-radius:var(--rl);padding:20px 24px;display:flex;gap:14px;align-items:flex-start}
.alert-box .ai{font-size:1.5rem;flex-shrink:0}
.alert-label{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--danger);margin-bottom:4px}
.alert-text{font-size:.875rem;color:var(--text2);line-height:1.55}

.iphone-wrap{display:flex;justify-content:center;animation:float 4s ease infinite}
.iphone{width:230px;background:#0f1a14;border-radius:36px;border:6px solid #253028;box-shadow:0 24px 64px rgba(0,0,0,.6),inset 0 0 0 1px rgba(255,255,255,.05);overflow:hidden}
.iphone-notch{width:76px;height:22px;background:#0f1a14;border-radius:0 0 14px 14px;margin:0 auto}
.iphone-screen{padding:8px 11px 14px}
.phone-header{font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-bottom:9px;padding-top:2px}
.phone-stats{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-bottom:8px}
.phone-stat{background:rgba(45,106,79,.2);border-radius:7px;padding:7px}
.phone-stat-n{font-size:.9rem;font-weight:700;color:#fff;font-family:var(--serif)}
.phone-stat-l{font-size:.56rem;color:rgba(244,239,230,.5);margin-top:1px}
.phone-stat.warn{background:rgba(212,136,58,.15)}
.phone-stat.warn .phone-stat-n{color:var(--warn)}
.phone-emp{background:rgba(255,255,255,.05);border-radius:7px;padding:7px 9px;margin-bottom:5px;display:flex;justify-content:space-between;align-items:center}
.phone-emp-name{font-size:.68rem;font-weight:600;color:#fff;margin-bottom:1px}
.phone-emp-role{font-size:.57rem;color:rgba(244,239,230,.4)}
.phone-badge{font-size:.57rem;font-weight:700;padding:2px 7px;border-radius:50px}
.phone-badge.ok{background:rgba(45,106,79,.25);color:#4CAF8A}
.phone-badge.warn{background:rgba(212,136,58,.2);color:var(--warn)}
.phone-badge.err{background:rgba(192,57,43,.2);color:#E05C5C}
.phone-btn{width:100%;background:var(--accent);border:none;border-radius:7px;padding:7px;font-size:.67rem;font-weight:600;color:#fff;margin-top:5px;cursor:default}

.cta-banner{background:var(--accent);padding:72px 32px;text-align:center}
.cta-banner h2{font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:700;color:#fff;margin-bottom:12px;letter-spacing:-.02em}
.cta-banner p{color:rgba(255,255,255,.82);font-size:1rem;margin-bottom:28px;max-width:480px;margin-left:auto;margin-right:auto}
.cta-banner-btn{background:#fff;color:var(--accent);font-family:var(--sans);font-size:.95rem;font-weight:700;padding:14px 36px;border-radius:var(--r);border:none;cursor:pointer;transition:all .25s;text-decoration:none;display:inline-block}
.cta-banner-btn:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(0,0,0,.2)}

.footer{background:var(--bg-dark);color:rgba(244,239,230,.6);padding:56px 32px 28px}
.footer-in{max-width:var(--max);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-logo-text{font-family:var(--serif);font-size:1.1rem;font-weight:600;color:var(--text-inv)}
.footer-logo-text b{color:var(--gold)}
.footer-brand p{font-size:.83rem;line-height:1.65;margin-top:8px}
.fc h4{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-inv);margin-bottom:13px}
.fc a{display:block;font-size:.84rem;padding:3px 0;color:rgba(244,239,230,.5);text-decoration:none;transition:color .2s}
.fc a:hover{color:var(--gold)}
.footer-bot{display:flex;justify-content:space-between;align-items:center;padding-top:20px;font-size:.78rem;flex-wrap:wrap;gap:10px}
.footer-bot-ls{display:flex;gap:18px}
.footer-bot-ls a{color:rgba(244,239,230,.35);text-decoration:none;transition:color .2s}
.footer-bot-ls a:hover{color:var(--gold)}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .hero-in.two-col,.grid-2{grid-template-columns:1fr}
  .grid-3,.grid-4,.grid-5{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats-bar-in{grid-template-columns:repeat(2,1fr)}
  .nav-center{display:none}
  .mob-tog{display:block}
}
@media(max-width:600px){
  .grid-3,.grid-4,.grid-5,.grid-auto{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .iphone-wrap{display:none}
  .sec{padding:48px 20px}
  .hero{padding:60px 20px 48px}
}

/* ── FORM INPUTS ── */
.fg{margin-bottom:18px}
.fg label{display:block;font-size:.82rem;font-weight:600;margin-bottom:6px}
.fg input,.fg select,.fg textarea{width:100%;padding:11px 14px;font-family:var(--sans);font-size:.92rem;border:1.5px solid var(--border);border-radius:var(--r);background:var(--bg);color:var(--text);outline:none;transition:border-color .2s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--accent)}
.fg textarea{resize:vertical;min-height:110px}

/* Auth */
.auth-wrap{min-height:calc(100vh - var(--nav) - 200px);display:flex;align-items:center;justify-content:center;padding:60px 20px;background:var(--bg-warm)}
.auth-box{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:40px;width:100%;max-width:420px;box-shadow:var(--sh2)}
.auth-box h2{font-family:var(--serif);font-size:1.6rem;font-weight:700;margin-bottom:6px}
.auth-sub{font-size:.875rem;color:var(--text2);margin-bottom:26px}
