/* ════════════════════════════════════════════════════════════
   tomhauck.de — „Tom Hauck · Web Developer & Designer"
   Dunkel · edel · modern-tech. Tiefes Schwarz + warmes Weiß + ein ruhiger Amber-Akzent.
   Eigenständig (nur diese Seite nutzt es — überschreibt style.css nicht).
   ════════════════════════════════════════════════════════════ */

/* ── Self-hosted Fonts (latin, woff2, variable) ───────────── */
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url('/fonts/HankenGrotesk.woff2') format('woff2');}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400 500;font-display:swap;src:url('/fonts/JetBrainsMono.woff2') format('woff2');}

:root{
  --bg:#0a0a0c;             /* tiefes Schwarz */
  --bg-2:#141417;           /* Karten/Flächen */
  --bg-3:#1b1b20;           /* erhöhte Flächen */
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.16);
  --text:#f4f2ec;           /* warmes Weiß */
  --text-soft:#c6c2ba;
  --muted:#8f8b82;
  --accent:#e3a44e;         /* warmes Amber / Kupfer */
  --accent-deep:#c8863a;
  --accent-soft:rgba(227,164,78,.13);
  --radius:14px;
  --maxw:1000px;
  --font-display:'Hanken Grotesk',system-ui,sans-serif;
  --font-body:'Hanken Grotesk',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
::selection{background:var(--accent);color:#16120a;}

/* ── Atmosphäre: dezenter Lichtschein, kein Chaos ─────────── */
.bg,.bg-grid,.bg-glow,.bg-grain,.cursor-glow{display:none!important;}
body::before{
  content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(70% 55% at 85% -5%, rgba(227,164,78,.10) 0%, rgba(227,164,78,0) 55%),
    radial-gradient(60% 50% at 10% 0%, rgba(120,140,200,.05) 0%, rgba(120,140,200,0) 50%);
}

/* ── Layout ───────────────────────────────────────────────── */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* ── Reveal (pure CSS) ────────────────────────────────────── */
@keyframes reveal{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}
.reveal{opacity:0;animation:reveal .7s cubic-bezier(.2,.7,.2,1) forwards;animation-delay:var(--d,0s);}

/* ── Navigation ───────────────────────────────────────────── */
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:26px 0 0;}
.nav-brand{display:inline-flex;align-items:center;gap:11px;}
.nav-logo{height:26px;width:auto;display:block;}
.nav-logo .cur{animation:cur-blink 1.1s step-end infinite;}
@keyframes cur-blink{50%{opacity:0;}}
.nav-word{font-family:var(--font-display);font-weight:700;font-size:1.15rem;letter-spacing:-.02em;color:var(--text);}
.nav-word .accent-dot{color:var(--accent);}
@media(max-width:560px){.nav-word{display:none;}}
.nav-links{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.82rem;}
.nav-links a{color:var(--text-soft);padding:8px 12px;border-radius:8px;transition:color .2s,background .2s;}
.nav-links a:hover{color:var(--text);background:rgba(255,255,255,.05);}
.nav-links .nav-cta{background:var(--accent);color:#16120a;font-weight:600;padding:8px 15px;}
.nav-links .nav-cta:hover{background:#eeb45f;color:#16120a;}
@media(max-width:560px){.nav-links a:not(.nav-cta){display:none;}}

/* ── Unterseiten-Kopf ─────────────────────────────────────── */
.page-head{padding:54px 0 36px;border-bottom:1px solid var(--line);margin-bottom:46px;}
.page-back{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.82rem;color:var(--text-soft);margin-bottom:26px;transition:color .2s,gap .2s;}
.page-back svg{width:15px;height:15px;}
.page-back:hover{color:var(--accent);gap:11px;}
.page-head h1{font-family:var(--font-display);font-weight:700;font-size:clamp(2.3rem,6vw,3.4rem);letter-spacing:-.03em;color:var(--text);margin-bottom:14px;}
.page-head .lead{color:var(--text-soft);font-size:1.05rem;max-width:56ch;}
.empty-note{color:var(--muted);font-family:var(--font-mono);font-size:.9rem;}

/* ── HERO ─────────────────────────────────────────────────── */
.hero{
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:52px;
  padding:64px 0 84px;border-bottom:1px solid var(--line);
}
.hero-main{order:1;}
.hero-portrait{order:2;display:flex;flex-direction:column;align-items:center;gap:16px;}
.portrait-frame{
  width:220px;aspect-ratio:4/5;border-radius:18px;overflow:hidden;
  background:var(--bg-2);border:1px solid var(--line-2);position:relative;
  box-shadow:0 40px 80px -30px rgba(0,0,0,.8), 0 0 0 1px rgba(227,164,78,.06);
}
.portrait-frame::after{content:'';position:absolute;inset:0;border-radius:18px;pointer-events:none;
  background:linear-gradient(180deg,rgba(10,10,12,0) 55%,rgba(10,10,12,.35) 100%);}
.portrait-img{display:block;width:100%;height:100%;object-fit:cover;object-position:center top;}
.mono-mark{font-family:var(--font-display);font-weight:700;font-size:4rem;color:var(--text);}

.status-pill{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.02em;
  color:var(--text-soft);background:var(--bg-2);
  border:1px solid var(--line);border-radius:99px;padding:6px 13px;
}
.status-dot{width:7px;height:7px;border-radius:50%;background:#43c478;box-shadow:0 0 0 3px rgba(67,196,120,.18);}

.eyebrow{font-family:var(--font-mono);font-size:.82rem;color:var(--muted);letter-spacing:.04em;margin-bottom:22px;}
.eyebrow .prompt{color:var(--accent);}
.hero-name{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(3.1rem,8.5vw,5.7rem);line-height:.98;letter-spacing:-.035em;
  color:var(--text);margin-bottom:18px;
}
.accent-dot{color:var(--accent);}
.hero-role{
  font-size:1.16rem;font-weight:500;color:var(--text-soft);
  letter-spacing:.005em;margin-bottom:26px;
}
.hero-bio{font-size:1.06rem;color:var(--text-soft);margin-bottom:38px;max-width:34ch;}
.hero-bio .tw{color:var(--accent);font-weight:600;}
.caret{display:inline-block;width:2px;height:1.05em;background:var(--accent);margin-left:2px;vertical-align:-2px;animation:blink 1.05s step-end infinite;}
@keyframes blink{50%{opacity:0;}}

.hero-cta{display:flex;flex-wrap:wrap;gap:14px;}
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-body);font-size:.96rem;font-weight:600;
  padding:13px 22px;border-radius:11px;cursor:pointer;border:1px solid transparent;
  transition:transform .15s ease,background .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease;
}
.btn i{font-size:.95em;}
.btn-primary{background:var(--accent);color:#16120a;box-shadow:0 8px 24px -10px rgba(227,164,78,.6);}
.btn-primary:hover{background:#eeb45f;transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line-2);}
.btn-ghost:hover{border-color:var(--text-soft);background:rgba(255,255,255,.04);transform:translateY(-2px);}

/* ── Sections ─────────────────────────────────────────────── */
.section{padding:64px 0;border-bottom:1px solid var(--line);}
.label{
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:.05em;
  text-transform:uppercase;color:var(--muted);margin-bottom:28px;
}
.label-mark{color:var(--accent);margin-right:6px;}

/* ── Skills / Stack ───────────────────────────────────────── */
.skills{display:flex;flex-wrap:wrap;gap:10px;}
.skill{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-mono);font-size:.86rem;color:var(--text-soft);
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:10px;padding:9px 15px;transition:border-color .2s,color .2s,transform .15s,background .2s;
}
.skill i{color:var(--accent);font-size:1em;}
.skill:hover{border-color:var(--line-2);color:var(--text);background:var(--bg-3);transform:translateY(-2px);}

/* ── Sicherheit ───────────────────────────────────────────── */
.sec{display:grid;gap:30px;}
.sec-head{max-width:64ch;}
.sec-title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,3.5vw,2.1rem);letter-spacing:-.02em;color:var(--text);margin-bottom:14px;line-height:1.18;}
.sec-lead{color:var(--text-soft);font-size:1.02rem;}
.sec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.sec-item{display:flex;gap:13px;align-items:flex-start;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:16px 17px;transition:border-color .2s,background .2s,transform .15s;}
.sec-item:hover{border-color:var(--line-2);background:var(--bg-3);transform:translateY(-2px);}
.sec-ico{flex-shrink:0;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent);border:1px solid rgba(227,164,78,.25);}
.sec-ico svg{width:19px;height:19px;}
.sec-item b{display:block;font-size:.95rem;color:var(--text);margin-bottom:3px;font-weight:700;}
.sec-item span{font-size:.83rem;color:var(--muted);line-height:1.45;}
@media(max-width:760px){.sec-grid{grid-template-columns:1fr;}}

/* ── Links / Karten ───────────────────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:40px;padding:64px 0;}
.two-col .section{padding:0;border:0;}
.links{display:flex;flex-direction:column;gap:12px;}
.card-row{
  display:flex;align-items:center;gap:15px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;transition:border-color .2s,transform .15s,box-shadow .2s,background .2s;
}
.card-row:hover{border-color:var(--line-2);background:var(--bg-3);transform:translateY(-2px);box-shadow:0 18px 40px -22px rgba(0,0,0,.8);}
.card-row.featured{border-color:rgba(227,164,78,.4);background:linear-gradient(180deg,var(--accent-soft),var(--bg-2));}
.card-ico{
  width:44px;height:44px;border-radius:11px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:1.15rem;
  background:rgba(255,255,255,.05)!important;color:var(--text)!important;border:1px solid var(--line);
}
.card-row.featured .card-ico{background:var(--accent-soft)!important;color:var(--accent)!important;border-color:rgba(227,164,78,.3);}
.card-body{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;}
.card-title{font-weight:700;font-size:1rem;color:var(--text);display:flex;align-items:center;gap:9px;}
.card-sub{font-size:.86rem;color:var(--muted);}
.badge-featured,.badge-status{
  font-family:var(--font-mono);font-size:.64rem;letter-spacing:.04em;text-transform:uppercase;
  background:var(--accent);color:#16120a;border-radius:5px;padding:2px 7px;font-weight:600;
}
.card-ext{color:var(--muted);font-size:.85rem;flex-shrink:0;transition:color .2s,transform .2s;}
.card-row:hover .card-ext{color:var(--accent);transform:translate(2px,-2px);}

/* ── Referenzen / Projekte (dynamisch) ────────────────────── */
.project-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
@media(max-width:760px){.project-list{grid-template-columns:1fr;}}

/* ── Footer (zentriert, Monospace, edel) ──────────────────── */
.footer{
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:11px;
  padding:62px 0 72px;
}
.foot-brand{font-family:var(--font-display);font-weight:700;font-size:1.55rem;letter-spacing:-.025em;color:var(--text);}
.foot-brand .accent-dot{color:var(--accent);}
.foot-tag{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.03em;color:var(--muted);}
.footer-legal{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:5px 7px;
  font-family:var(--font-mono);font-size:.8rem;margin-top:6px;}
.footer-legal a{color:var(--text-soft);transition:color .2s;}
.footer-legal a:hover{color:var(--accent);}
.foot-copy{font-family:var(--font-mono);font-size:.72rem;color:var(--muted);margin-top:8px;}
.dot-sep{color:var(--line-2);}

#toast-container{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:9990;}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width:760px){
  .hero{grid-template-columns:1fr;padding:80px 0 52px;gap:30px;}
  .hero-portrait{order:-1;align-items:flex-start;}
  .portrait-frame{width:134px;border-radius:14px;}
  .mono-mark{font-size:2.6rem;}
  .two-col{grid-template-columns:1fr;gap:32px;}
  .section{padding:48px 0;}
}
@media (prefers-reduced-motion:reduce){
  .reveal{animation:none;opacity:1;}
  .caret,.status-dot,.nav-logo .cur{animation:none;}
}
/* ── Font Awesome (Subset, self-hosted) ── */
.fa-solid,.fas,.fa-brands,.fab{display:inline-block;font-style:normal;font-variant:normal;line-height:1;text-rendering:auto;-webkit-font-smoothing:antialiased;}
.fa-solid,.fas{font-family:'Font Awesome 6 Free';font-weight:900;}
.fa-brands,.fab{font-family:'Font Awesome 6 Brands';font-weight:400;}
.fa-spin{animation:fa-spin 1s linear infinite;}@keyframes fa-spin{to{transform:rotate(360deg);}}
@font-face{font-family:'Font Awesome 6 Free';font-style:normal;font-weight:900;font-display:swap;src:url('/fonts/fa-solid.woff2') format('woff2');}
/* fa-solid: 10 icons */
.fa-code-branch::before{content:"\f126"}
.fa-database::before{content:"\f1c0"}
.fa-envelope::before{content:"\f0e0"}
.fa-mobile-screen::before{content:"\f3cf"}
.fa-paper-plane::before{content:"\f1d8"}
.fa-server::before{content:"\f233"}
.fa-spinner::before{content:"\f110"}
.fa-user::before{content:"\f007"}
.fa-wand-magic-sparkles::before{content:"\e2ca"}
.fa-xmark::before{content:"\f00d"}
@font-face{font-family:'Font Awesome 6 Brands';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/fa-brands.woff2') format('woff2');}
/* fa-brands: 10 icons */
.fa-css3-alt::before{content:"\f38b"}
.fa-discord::before{content:"\f392"}
.fa-docker::before{content:"\f395"}
.fa-git-alt::before{content:"\f841"}
.fa-github::before{content:"\f09b"}
.fa-html5::before{content:"\f13b"}
.fa-js::before{content:"\f3b8"}
.fa-linux::before{content:"\f17c"}
.fa-node-js::before{content:"\f3d3"}
.fa-php::before{content:"\f457"}

/* ── Rechtstexte (Impressum / Datenschutz / AGB) ──────────── */
.legal-wrap{position:relative;max-width:760px;margin:0 auto;padding:clamp(2.5rem,6vw,4rem) 24px 6rem;}
.legal-back{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.82rem;font-weight:500;color:var(--text-soft);margin-bottom:2rem;transition:color .2s,gap .2s;}
.legal-back svg{width:15px;height:15px;}
.legal-back:hover{color:var(--accent);gap:11px;}
.legal h1{font-family:var(--font-display);font-weight:700;font-size:clamp(1.9rem,5vw,2.6rem);letter-spacing:-.03em;color:var(--text);margin-bottom:.4rem;}
.legal .updated{font-family:var(--font-mono);font-size:.78rem;color:var(--muted);margin-bottom:2rem;}
.legal h2{font-family:var(--font-display);font-weight:700;font-size:1.18rem;color:var(--text);margin:2rem 0 .7rem;padding-top:1.2rem;border-top:1px solid var(--line);}
.legal h3{font-size:.98rem;font-weight:700;color:var(--text);margin:1.4rem 0 .5rem;}
.legal p,.legal li{font-size:.93rem;color:var(--text-soft);line-height:1.75;}
.legal p{margin-bottom:.9rem;}
.legal ul,.legal ol{margin:0 0 .9rem 1.25rem;}
.legal li{margin-bottom:.4rem;}
.legal a{color:var(--accent);border-bottom:1px solid transparent;transition:border-color .2s;}
.legal a:hover{border-color:var(--accent);}
.legal strong{color:var(--text);font-weight:600;}
.legal address{font-style:normal;}
.legal .ph{color:var(--accent);background:var(--accent-soft);border:1px dashed rgba(227,164,78,.4);padding:1px 7px;border-radius:5px;font-family:var(--font-mono);font-size:.86em;}
.legal-card{background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin:1rem 0;}
.legal-foot{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:16px;font-family:var(--font-mono);font-size:.8rem;}
.legal-foot a{color:var(--text-soft);}
.legal-foot a:hover{color:var(--accent);}
