/* =========================================================================
   Saschas Fotowelt — „Fotograf auf Ballhöhe"
   Sport-Editorial-Design. Fonts: Big Shoulders Display / Manrope / JetBrains Mono
   ========================================================================= */
:root{
  --ink:#0c0c0a;
  --ink-2:#1a1a17;
  --paper:#f3efe5;
  --paper-2:#ebe6d8;
  --line:#d8d2bf;
  --muted:#7b766a;
  --signal:#e8472b;      /* Flutlicht-Signal */
  --pitch:#1c3a26;       /* tiefes Grün */
  --chalk:#f8f5ed;
  --maxw:1400px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);
  font-family:"Manrope",system-ui,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.display{font-family:"Big Shoulders Display",sans-serif;text-transform:uppercase;font-weight:800;line-height:.9}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace;letter-spacing:.02em}
.eyebrow{font-family:"JetBrains Mono",ui-monospace,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
h1,h2,h3,h4{font-family:"Big Shoulders Display",sans-serif;text-transform:uppercase;font-weight:800;line-height:.92;letter-spacing:-.005em}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:11px 18px;border-radius:2px;font-weight:600;
  font-size:13px;letter-spacing:.02em;border:1px solid transparent;cursor:pointer;transition:.15s ease;font-family:"Manrope",sans-serif}
.btn-ink,.btn:not(.btn-ghost):not(.btn-danger){background:var(--ink);color:var(--paper)}
.btn-ink:hover,.btn:not(.btn-ghost):not(.btn-danger):hover{background:var(--signal);color:var(--paper)}
.btn-ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-danger{background:var(--signal);color:var(--paper);border-color:var(--signal)}
.btn-danger:hover{background:#c2371f}
.btn-small{padding:8px 14px;font-size:12px}
.btn-tiny{padding:6px 11px;font-size:11px}
.btn .arrow{transition:transform .2s ease}
.btn:hover .arrow{transform:translateX(3px)}

/* ---- NAV / Header ------------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:60;backdrop-filter:saturate(120%) blur(8px);
  background:rgba(243,239,229,.85);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 32px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:38px;height:38px;border-radius:4px;background:var(--ink);display:grid;place-items:center;color:var(--paper);
  font-family:"Big Shoulders Display";font-weight:900;font-size:22px;letter-spacing:.02em;overflow:hidden}
.brand-mark img{width:100%;height:100%;object-fit:cover}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text .b1{font-family:"Big Shoulders Display";font-weight:800;font-size:22px;letter-spacing:.005em;text-transform:uppercase}
.brand-text .b2{font-family:"JetBrains Mono";font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.site-nav{display:flex;align-items:center;gap:26px}
.site-nav a{font-size:14px;font-weight:500;color:var(--ink);position:relative;padding:6px 0}
.site-nav a:hover{color:var(--signal)}
.site-nav a[aria-current]::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--signal)}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-cart{position:relative}
.cart-badge{background:var(--signal);color:var(--paper);border-radius:10px;font-size:11px;padding:1px 7px;margin-left:2px}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.nav-burger span{width:24px;height:2px;background:var(--ink)}
.nav-toggle{display:none}

/* ---- Flash -------------------------------------------------------------- */
.flash{padding:13px 18px;border-radius:2px;margin:16px 0;font-size:14px;font-weight:500;border-left:3px solid}
.flash-success{background:#e7efe4;color:#234d2a;border-color:var(--pitch)}
.flash-error{background:#fbe6e1;color:#8f2a18;border-color:var(--signal)}
.flash-info{background:var(--paper-2);color:var(--ink-2);border-color:var(--ink)}

/* ---- HERO (Start) ------------------------------------------------------- */
.hero{position:relative;background:var(--ink);color:var(--paper);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;min-height:680px}
.hero-left{padding:80px 56px 56px;display:flex;flex-direction:column;justify-content:space-between}
.hero-meta{display:flex;align-items:center;gap:18px}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--signal);box-shadow:0 0 0 4px rgba(232,71,43,.18);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(232,71,43,.18)}50%{box-shadow:0 0 0 9px rgba(232,71,43,.06)}}
.hero h1{font-family:"Big Shoulders Display";font-weight:900;font-size:clamp(64px,10vw,160px);line-height:.84;
  letter-spacing:-.01em;margin:32px 0 0;text-transform:uppercase}
.hero h1 .em{color:var(--signal);font-style:italic}
.hero h1 .stroke{-webkit-text-stroke:1.5px var(--paper);color:transparent}
.hero .lede{font-size:18px;line-height:1.55;max-width:480px;color:#d9d5c6;margin-top:28px}
.hero-actions{display:flex;gap:12px;margin-top:36px;flex-wrap:wrap}
.hero-actions .btn-ink{background:var(--paper);color:var(--ink)}
.hero-actions .btn-ink:hover{background:var(--signal);color:var(--paper)}
.hero-actions .btn-ghost{border-color:rgba(255,255,255,.4);color:var(--paper)}
.hero-actions .btn-ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.hero-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-top:auto;padding-top:48px;border-top:1px solid rgba(255,255,255,.1)}
.stat{display:flex;flex-direction:column;gap:4px}
.stat .v{font-family:"Big Shoulders Display";font-weight:800;font-size:42px;line-height:1}
.stat .l{font-family:"JetBrains Mono";font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:#a8a397}
.hero-right{position:relative;background:#111;overflow:hidden;min-height:420px}
.hero-right img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.hero-right .hero-empty{position:absolute;inset:0;display:grid;place-items:center;color:#3a382f;font-family:"JetBrains Mono";font-size:12px;letter-spacing:.15em;text-transform:uppercase}
.hero-side-meta{position:absolute;right:24px;top:24px;display:flex;flex-direction:column;gap:6px;align-items:flex-end;z-index:2}
.chip{font-family:"JetBrains Mono";font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:6px 10px;background:rgba(12,12,10,.8);color:var(--paper);border:1px solid rgba(255,255,255,.15)}

/* ---- TICKER ------------------------------------------------------------- */
.ticker{background:var(--signal);color:var(--paper);overflow:hidden;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.ticker-track{display:flex;gap:48px;padding:14px 0;animation:slide 32s linear infinite;white-space:nowrap;
  font-family:"Big Shoulders Display";font-weight:800;font-size:18px;letter-spacing:.04em;text-transform:uppercase}
.ticker-track span{display:inline-flex;align-items:center;gap:48px}
.ticker-track .dot{width:6px;height:6px;background:var(--paper);border-radius:50%;display:inline-block}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- SECTIONS ----------------------------------------------------------- */
.section,section.block{padding:88px 0}
.section.narrow{max-width:720px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:48px;flex-wrap:wrap}
.section-head h2,.section-title{font-family:"Big Shoulders Display";font-weight:800;font-size:clamp(40px,6vw,80px);
  margin:8px 0 0;line-height:.9;text-transform:uppercase;letter-spacing:-.01em}
.section-head .link{font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:8px;border-bottom:1px solid var(--ink);padding-bottom:4px}
.section-head .link:hover{color:var(--signal);border-color:var(--signal)}
.page-head{margin-bottom:40px}
.page-title{font-family:"Big Shoulders Display";font-weight:900;font-size:clamp(48px,8vw,120px);line-height:.85;text-transform:uppercase;letter-spacing:-.01em;margin:8px 0 0}
.page-sub{color:var(--muted);margin:14px 0 0;font-size:16px}
.center{text-align:center;margin-top:36px}
.placeholder-note{background:var(--paper-2);padding:24px;color:var(--ink-2);border-left:3px solid var(--signal);font-size:15px}
.link-arrow{border-bottom:1px solid var(--ink);padding-bottom:2px;font-weight:600}
.link-arrow:hover{color:var(--signal);border-color:var(--signal)}
.draft-badge{display:inline-block;background:var(--signal);color:var(--paper);padding:5px 12px;font-family:"JetBrains Mono";
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;margin-bottom:12px}

/* ---- MATCH-CARDS (Galerie-Liste / Start) -------------------------------- */
.matches{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}
.match,.gcard{position:relative;background:var(--ink);color:var(--paper);overflow:hidden;display:block;min-height:340px;transition:transform .3s ease}
.match:hover,.gcard:hover{transform:translateY(-4px)}
.match.featured{grid-column:span 1;grid-row:span 2;min-height:560px}
.match-img,.gcard-img{position:absolute;inset:0;overflow:hidden;background:#0a0a08}
.match-img img,.gcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.match:hover .match-img img,.gcard:hover .gcard-img img{transform:scale(1.04)}
.match-img::after,.gcard-img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,0) 55%)}
.gcard-empty{position:absolute;inset:0;display:grid;place-items:center;color:#3a382f;font-family:"JetBrains Mono";font-size:12px;text-transform:uppercase;letter-spacing:.12em}
.match-tag,.gcard-tags{position:absolute;top:16px;left:16px;z-index:2;display:flex;gap:6px}
.tag{font-family:"JetBrains Mono";font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:5px 9px;background:var(--paper);color:var(--ink);font-weight:500}
.tag.signal{background:var(--signal);color:var(--paper)}
.match-body,.gcard-body{position:absolute;bottom:0;left:0;right:0;padding:24px;z-index:2}
.match-date,.gcard-date{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.15em;color:#bdb8a8;text-transform:uppercase;margin-bottom:8px}
.match-title,.gcard-body h3{font-family:"Big Shoulders Display";font-weight:800;font-size:30px;line-height:.95;text-transform:uppercase;letter-spacing:-.005em;margin:0;color:var(--paper)}
.match.featured .match-title{font-size:52px}
.match-foot,.gcard-foot{margin-top:14px;display:flex;justify-content:space-between;align-items:center;
  font-family:"JetBrains Mono";font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#bdb8a8}
.match:hover .match-foot .arrow,.gcard:hover .gcard-foot .arrow{transform:translateX(4px);color:var(--signal)}

/* ---- ABOUT (Über mich / Start-Teaser) ----------------------------------- */
.about{background:var(--paper-2)}
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.about-portrait,.about-photo{aspect-ratio:4/5;background:var(--ink);position:relative;overflow:hidden}
.about-portrait img,.about-photo img{width:100%;height:100%;object-fit:cover}
.about-text h3{font-family:"Big Shoulders Display";font-weight:800;font-size:clamp(40px,5vw,64px);line-height:.92;text-transform:uppercase;margin:8px 0 24px;letter-spacing:-.005em}
.about-text p{font-size:17px;line-height:1.65;color:#3a382f;max-width:520px}
.services{list-style:none;margin:32px 0 24px;padding:0;border-top:1px solid var(--line)}
.services li{padding:16px 0;border-bottom:1px solid var(--line);font-size:16px}
.services li strong{font-family:"Big Shoulders Display";font-weight:700;text-transform:uppercase;letter-spacing:.005em;font-size:18px}

/* ---- SERVICES / PROCESS ------------------------------------------------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.service{padding:40px 32px;border-right:1px solid var(--line)}
.service:last-child{border-right:none}
.service .num{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.18em;color:var(--muted)}
.service h4{font-family:"Big Shoulders Display";font-weight:800;font-size:36px;text-transform:uppercase;margin:40px 0 12px;line-height:.95}
.service p{font-size:15px;line-height:1.6;color:#3a382f;margin:0 0 24px}
.service ul{margin:0;padding:0;list-style:none;border-top:1px solid var(--line)}
.service li{padding:12px 0;border-bottom:1px solid var(--line);font-size:13px;display:flex;justify-content:space-between;color:var(--muted)}
.service li b{color:var(--ink);font-weight:600}

/* ---- QUOTE -------------------------------------------------------------- */
.quote{background:var(--ink);color:var(--paper);padding:110px 0}
.quote-inner{max-width:1100px;margin:0 auto;padding:0 32px;text-align:center}
.quote q{font-family:"Big Shoulders Display";font-weight:700;font-size:clamp(32px,5vw,68px);line-height:1.02;text-transform:uppercase;letter-spacing:-.005em;font-style:italic}
.quote .by{margin-top:32px;font-family:"JetBrains Mono";font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#a8a397}

/* ---- CONTACT-CTA -------------------------------------------------------- */
.contact-cta-block{background:var(--signal);color:var(--paper)}
.contact-cta-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:end;padding:88px 0}
.contact-cta-grid h2{font-family:"Big Shoulders Display";font-weight:900;font-size:clamp(56px,8vw,128px);line-height:.86;text-transform:uppercase;letter-spacing:-.01em;margin:0}
.contact-cta-grid h2 .stroke{-webkit-text-stroke:2px var(--paper);color:transparent}
.contact-info{display:grid;gap:0}
.contact-info .row{display:grid;grid-template-columns:120px 1fr;gap:24px;padding:18px 0;border-top:1px solid rgba(255,255,255,.3);font-size:15px}
.contact-info .row:last-child{border-bottom:1px solid rgba(255,255,255,.3)}
.contact-info .row .k{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.18em;text-transform:uppercase;align-self:center;opacity:.85}
.contact-info .row .v{font-family:"Big Shoulders Display";font-weight:700;font-size:22px;text-transform:uppercase}

/* ---- GALERIE-DETAIL: Crumbs / Scoreboard / Buybar ----------------------- */
.crumbs{padding:24px 0 0;font-family:"JetBrains Mono";font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.crumbs a:hover{color:var(--signal)}
.crumbs .sep{opacity:.4}
.match-head{padding:28px 0 48px}
.match-meta{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:8px}
.pill{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:6px 10px;background:var(--ink);color:var(--paper)}
.pill.signal{background:var(--signal)}
.pill.ghost{background:transparent;border:1px solid var(--ink);color:var(--ink)}
.scoreboard{display:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:center;margin-top:28px;padding:36px 0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.team{display:flex;align-items:center;gap:20px}
.team.right{justify-content:flex-end;flex-direction:row-reverse;text-align:right}
.crest{width:72px;height:72px;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-family:"Big Shoulders Display";font-weight:900;font-size:30px;border-radius:2px;flex-shrink:0}
.crest.alt{background:var(--signal)}
.team .name{font-family:"Big Shoulders Display";font-weight:800;font-size:clamp(28px,3.5vw,48px);line-height:.95;text-transform:uppercase;letter-spacing:-.005em}
.team .sub{font-family:"JetBrains Mono";font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.versus{font-family:"Big Shoulders Display";font-weight:900;font-size:56px;line-height:1;color:var(--ink);opacity:.2;letter-spacing:-.02em}
.gallery-desc{margin-top:24px;font-size:16px;line-height:1.65;color:#3a382f;max-width:680px}
.buybar{margin-top:28px;background:var(--ink);color:var(--paper);display:flex;gap:24px;align-items:center;justify-content:space-between;padding:22px 26px;flex-wrap:wrap}
.buybar .info{display:flex;gap:32px;flex-wrap:wrap;align-items:center}
.buybar .info .k{font-family:"JetBrains Mono";font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#a8a397}
.buybar .info .v{font-family:"Big Shoulders Display";font-weight:700;font-size:24px;margin-top:4px}
.buybar .btn-ink{background:var(--paper);color:var(--ink)}
.buybar .btn-ink:hover{background:var(--signal);color:var(--paper)}

/* ---- EDITORIAL GALLERY GRID --------------------------------------------- */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;padding-bottom:32px}
.gallery-item{position:relative;margin:0;background:var(--ink);overflow:hidden;grid-column:span 4;aspect-ratio:4/3}
.gallery-item:nth-child(8n+1){grid-column:span 6;aspect-ratio:16/10}
.gallery-item:nth-child(8n+4){grid-column:span 6;aspect-ratio:3/2}
.gallery-item:nth-child(8n+6){grid-column:span 3;aspect-ratio:3/4}
.gallery-item:nth-child(8n+7){grid-column:span 3;aspect-ratio:3/4}
.gallery-trigger{padding:0;border:0;background:none;cursor:zoom-in;width:100%;height:100%;display:block}
.gallery-trigger img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.gallery-item:hover .gallery-trigger img{transform:scale(1.04)}
.gallery-num{position:absolute;top:12px;left:12px;font-family:"JetBrains Mono";font-size:10px;letter-spacing:.15em;color:var(--paper);background:rgba(0,0,0,.55);padding:4px 8px;z-index:3}
.gallery-actions{position:absolute;bottom:0;left:0;right:0;display:flex;gap:8px;justify-content:flex-end;align-items:center;
  padding:12px;z-index:3;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);opacity:0;transform:translateY(8px);transition:.2s}
.gallery-item:hover .gallery-actions{opacity:1;transform:translateY(0)}

/* ---- FORMS -------------------------------------------------------------- */
.form{display:flex;flex-direction:column;gap:18px;max-width:520px}
.form label{display:flex;flex-direction:column;gap:8px;font-family:"JetBrains Mono";font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.form input,.form textarea,.form select{font-family:"Manrope",sans-serif;font-size:16px;padding:12px 14px;border:1px solid var(--line);
  border-radius:2px;background:var(--chalk);color:var(--ink);transition:border-color .2s}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--signal)}
.form textarea{resize:vertical;min-height:120px}
.form .btn{align-self:flex-start}
.form-alt{margin-top:18px;color:var(--muted);font-size:14px}
.form-alt a{border-bottom:1px solid var(--ink);font-weight:600}

/* ---- TABLES (Warenkorb, Bestellungen, Konto) ---------------------------- */
.table{width:100%;border-collapse:collapse;margin:18px 0;font-size:15px}
.table th,.table td{text-align:left;padding:14px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.table thead th{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:500}
.table tfoot th{border-top:2px solid var(--ink);font-family:"Big Shoulders Display";font-size:20px;text-transform:uppercase}
.cart-thumb{width:90px;margin-top:6px}
.cart-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}
.inline{display:inline}
.status{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px}
.status-offen{background:#f6e7c8;color:#7a5c00}
.status-bezahlt{background:#e7efe4;color:#234d2a}
.status-erledigt{background:#dde8f2;color:#1c4f86}
.status-storniert{background:var(--paper-2);color:var(--muted)}

/* ---- FOTO-DETAILSEITE --------------------------------------------------- */
.foto-page .foto-main{margin:20px 0;background:var(--ink)}
.foto-page .foto-main img{max-width:100%;max-height:78vh;margin:0 auto;display:block}
.foto-rating-summary{display:flex;gap:14px;align-items:center;margin-bottom:30px}
.stars{color:var(--signal);letter-spacing:2px;font-size:20px}
.comment-form{max-width:560px}
.comment-list{list-style:none;padding:0;margin:0}
.comment-list li{padding:18px 0;border-bottom:1px solid var(--line)}
.comment-head{display:flex;gap:12px;align-items:center;margin-bottom:6px}
.comment-head strong{font-family:"Big Shoulders Display";text-transform:uppercase;font-size:18px;letter-spacing:.01em}
.comment-head time{font-family:"JetBrains Mono";font-size:11px;color:var(--muted)}
.comment-list p{margin:0;color:#3a382f}
/* Sterne-Eingabe (reverse-order, ohne JS) */
.star-input{display:inline-flex;flex-direction:row-reverse;justify-content:flex-end;font-size:32px}
.star-input input{display:none}
.star-input label{color:var(--line);cursor:pointer;padding:0 2px;transition:color .15s}
.star-input input:checked ~ label,.star-input label:hover,.star-input label:hover ~ label{color:var(--signal)}

/* ---- DANKSAGUNGEN ------------------------------------------------------- */
.thanks-grid{columns:3 300px;column-gap:24px}
.thanks-card{margin:0 0 24px;break-inside:avoid;background:var(--ink);color:var(--paper);padding:28px 26px;border-top:3px solid var(--signal)}
.thanks-card blockquote{margin:0 0 16px;font-family:"Big Shoulders Display";font-weight:700;font-size:24px;line-height:1.05;text-transform:uppercase;letter-spacing:-.005em}
.thanks-card figcaption{display:flex;flex-direction:column;gap:3px;font-size:13px}
.thanks-card figcaption strong{color:var(--paper)}
.thanks-card figcaption .muted{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#a8a397}

/* ---- FOOTER ------------------------------------------------------------- */
.site-footer{background:var(--ink);color:#bdb8a8;padding:56px 0 32px;margin-top:0}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.site-footer .brand-text .b1{color:var(--paper)}
.site-footer .brand-text .b2{color:#777268}
.foot-about{margin-top:18px;max-width:340px;font-size:14px;line-height:1.6;color:#a8a397}
.foot-col h5{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#777268;margin:0 0 16px;font-weight:500}
.foot-col a{display:block;font-size:14px;padding:6px 0;color:#d9d5c6}
.foot-col a:hover{color:var(--signal)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:24px;
  font-family:"JetBrains Mono";font-size:11px;letter-spacing:.1em;color:#777268;text-transform:uppercase;gap:16px;flex-wrap:wrap}

/* ---- LIGHTBOX ----------------------------------------------------------- */
.lightbox{position:fixed;inset:0;background:rgba(12,12,10,.96);z-index:200;display:flex;align-items:center;justify-content:center}
.lightbox[hidden]{display:none}
.lightbox-content{margin:0;max-width:90vw;max-height:88vh;text-align:center}
.lightbox-content img{max-width:90vw;max-height:82vh;object-fit:contain;margin:0 auto}
.lightbox-content figcaption{color:#bdb8a8;font-family:"JetBrains Mono";font-size:12px;letter-spacing:.1em;margin-top:12px;text-transform:uppercase}
.lightbox-close{position:absolute;top:18px;right:24px;background:none;border:0;color:var(--paper);font-size:40px;cursor:pointer;line-height:1}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:0;color:var(--paper);font-size:60px;cursor:pointer;padding:0 24px;opacity:.7}
.lightbox-nav:hover{opacity:1;color:var(--signal)}
.lightbox-prev{left:0}.lightbox-next{right:0}

/* ---- RESPONSIVE --------------------------------------------------------- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-left{padding:48px 28px}
  .matches{grid-template-columns:1fr 1fr}
  .match.featured{grid-row:auto;grid-column:span 2}
  .about-grid{grid-template-columns:1fr;gap:32px}
  .services-grid{grid-template-columns:1fr}
  .service{border-right:none;border-bottom:1px solid var(--line)}
  .contact-cta-grid{grid-template-columns:1fr;gap:40px;padding:56px 0}
  .scoreboard{grid-template-columns:1fr;text-align:center;gap:18px}
  .team,.team.right{flex-direction:column;text-align:center}
  .gallery{grid-template-columns:repeat(6,1fr)}
  .gallery-item,.gallery-item:nth-child(8n+1),.gallery-item:nth-child(8n+4),.gallery-item:nth-child(8n+6),.gallery-item:nth-child(8n+7){grid-column:span 3;aspect-ratio:1}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .wrap{padding:0 20px}
  .header-inner{padding:14px 20px}
  .nav-burger{display:flex}
  .site-nav{position:fixed;inset:70px 0 auto 0;background:var(--paper);flex-direction:column;gap:0;
    border-bottom:1px solid var(--line);padding:8px 20px;display:none}
  .nav-toggle:checked ~ .site-nav{display:flex}
  .site-nav a{padding:14px 0;width:100%;border-bottom:1px solid var(--line)}
  .nav-actions{display:none}
}
@media (max-width:560px){
  .matches,.gallery,.gallery-item{grid-template-columns:1fr}
  .match.featured{grid-column:span 1}
  .gallery-item,.gallery-item:nth-child(n){grid-column:span 1;aspect-ratio:4/3}
}
