*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:
    radial-gradient(circle at top left, rgba(198,163,109,.12), transparent 26%),
    radial-gradient(circle at 85% 18%, rgba(99,117,150,.10), transparent 24%),
    linear-gradient(180deg,#0e0f11 0%,#131416 52%,#111214 100%);
  --surface:rgba(18,19,21,.86);
  --surface-solid:#14161a;
  --surface-soft:#17191d;
  --ink:#f2eee7;
  --text:rgba(228,222,212,.78);
  --muted:rgba(200,194,184,.66);
  --line:rgba(255,255,255,.08);
  --shadow:0 22px 60px rgba(0,0,0,.28);
  --hero:#0d0e10;
  --hero-text:#f6f2eb;
  --hero-soft:rgba(244,239,231,.74);
  --btn:#f3efe7;
  --btn-text:#111214;
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:'Geist',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.72;
  overflow-x:hidden;
}
body.consent-open{
  overflow:hidden;
}
::selection{background:var(--ink);color:#111214}
a{color:inherit}
img{display:block;max-width:100%}
.page{
  width:calc(100% - 24px);
  margin:0 auto;
  padding:16px 0 56px;
}
.topbar{
  position:sticky;
  top:16px;
  z-index:460;
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:16px;
  width:min(1380px, calc(100% - 40px));
  margin:0 auto;
  padding:12px;
  border-radius:32px;
  background:var(--surface);
  border:1px solid var(--line);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  box-shadow:0 12px 36px rgba(0,0,0,.34);
  overflow:visible;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
  padding:9px 18px 9px 9px;
  border-radius:24px;
  text-decoration:none;
  background:linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.02) 100%);
  border:1px solid rgba(255,255,255,.06);
  min-height:70px;
}
.brand-icon{
  width:74px;
  height:74px;
  border-radius:20px;
  overflow:hidden;
  background:
    radial-gradient(circle at 30% 20%, rgba(49,51,55,.92), rgba(23,25,28,.92)),
    linear-gradient(180deg,#1c1f23 0%,#121417 100%);
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  box-shadow:0 12px 28px rgba(0,0,0,.14);
}
.brand-icon img{
  width:112%;
  height:112%;
  object-fit:cover;
  object-position:center 44%;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.22));
  transform:translateY(10%) scale(1.4);
}
.brand-copy{min-width:0}
.brand-name{
  display:block;
  font-size:20px;
  font-weight:800;
  letter-spacing:-.045em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.brand-tagline{
  display:block;
  font-size:12px;
  font-weight:650;
  color:var(--muted);
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.topbar-center{
  min-width:0;
  display:flex;
  justify-content:center;
}
.topbar-nav{
  display:flex;
  list-style:none;
  gap:4px;
  align-items:center;
  padding:6px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.02) 100%);
  border:1px solid rgba(255,255,255,.06);
  max-width:100%;
  overflow:auto;
}
.topbar-nav a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:0 20px;
  border-radius:999px;
  text-decoration:none;
  white-space:nowrap;
  color:var(--muted);
  font-size:14px;
  font-weight:650;
  transition:background .2s ease,color .2s ease,transform .2s ease;
}
.topbar-nav a:hover,
.topbar-nav a.is-active{
  color:var(--ink);
  background:rgba(255,255,255,.08);
  transform:translateY(-1px);
}
.topbar-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
}
.topbar-mobile-toggle{
  display:none;
  width:46px;
  height:46px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  color:var(--ink);
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.topbar-mobile-toggle svg{
  width:20px;
  height:20px;
  stroke:currentColor;
  fill:none;
  stroke-width:1.8;
  stroke-linecap:round;
}
.topbar-mobile-panel{
  position:absolute;
  left:0;
  right:0;
  top:calc(100% + 10px);
  padding:10px;
  border-radius:24px;
  background:rgba(15,16,19,.96);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  display:none;
}
.topbar-mobile-panel.is-open{display:grid;gap:10px}
.topbar-mobile-panel nav{display:grid;gap:6px}
.topbar-mobile-panel nav a{
  min-height:48px;
  padding:0 16px;
  border-radius:16px;
  display:flex;
  align-items:center;
  text-decoration:none;
  color:var(--ink);
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
  font-size:14px;
  font-weight:650;
}
.topbar-mobile-panel nav a.is-active{
  background:rgba(255,255,255,.08);
}
.topbar-mobile-actions{
  display:grid;
  gap:8px;
}
.back-link,
.nav-contact{
  min-height:50px;
  padding:0 24px;
  border-radius:999px;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  font-weight:750;
  letter-spacing:-.02em;
}
.back-link{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  color:var(--ink);
}
.nav-contact{
  background:var(--btn);
  color:var(--btn-text);
}
.hero{
  margin-top:18px;
  padding:34px;
  border-radius:34px;
  background:linear-gradient(180deg, rgba(17,18,20,.98) 0%, rgba(12,13,15,.98) 100%);
  border:1px solid rgba(255,255,255,.06);
  color:var(--hero-text);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.hero::after{
  content:"";
  position:absolute;
  right:-4%;
  top:52%;
  width:min(44vw, 620px);
  aspect-ratio:1 / 1;
  transform:translateY(-50%) rotate(-12deg);
  background:url("../assets/branding/teuto-logo-full-final.png") center / contain no-repeat;
  opacity:.08;
  filter:grayscale(1) brightness(1.35) contrast(1.02);
  pointer-events:none;
}
.hero > *{
  position:relative;
  z-index:1;
}
.eyebrow{
  display:inline-flex;
  margin-bottom:14px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(200,194,184,.58);
}
.hero h1{
  font-size:clamp(34px,6vw,72px);
  line-height:.95;
  letter-spacing:-.06em;
  max-width:900px;
  margin-bottom:16px;
}
.hero p{
  max-width:760px;
  font-size:16px;
  line-height:1.82;
  color:var(--hero-soft);
}
.content-card,
.side-card{
  margin-top:18px;
  border-radius:30px;
  background:var(--surface);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.content-card{padding:32px 28px}
.content-card h2{
  font-size:22px;
  font-weight:800;
  letter-spacing:-.03em;
  margin:26px 0 10px;
}
.content-card h2:first-child{margin-top:0}
.content-card p,
.content-card li{font-size:14px;color:var(--text)}
.content-card ul{padding-left:18px}
.content-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(280px,.58fr);
  gap:18px;
  align-items:start;
}
.side-card{
  position:sticky;
  top:98px;
  padding:24px;
}
.section-title,
.side-title{
  font-size:28px;
  line-height:1;
  letter-spacing:-.04em;
  margin-bottom:20px;
}
.side-copy{
  font-size:14px;
  color:var(--text);
  line-height:1.75;
  margin-bottom:18px;
}
.contact-list{
  display:grid;
  gap:10px;
  margin-bottom:18px;
}
.contact-item{
  padding:14px 16px;
  border-radius:18px;
  background:var(--surface-soft);
  border:1px solid var(--line);
}
.contact-item strong{
  display:block;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:4px;
}
.contact-item span,
.contact-item a{
  font-size:14px;
  color:var(--ink);
  text-decoration:none;
}
.note{
  margin-top:24px;
  padding:16px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:var(--muted);
  font-size:13px;
}
.floating-contact{
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:440;
  min-height:54px;
  padding:0 20px;
  border-radius:999px;
  background:#f3efe7;
  color:#111214;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  font-weight:800;
  letter-spacing:-.02em;
  box-shadow:0 18px 42px rgba(0,0,0,.24);
}

.contact-layout{
  margin-top:18px;
  display:grid;
  grid-template-columns:minmax(300px,.8fr) minmax(0,1.2fr);
  gap:18px;
  align-items:start;
}
.contact-panel,
.contact-form-panel{
  border-radius:30px;
  background:var(--surface);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.contact-panel{padding:28px}
.contact-form-panel{padding:28px}
.contact-grid{
  display:grid;
  gap:12px;
}
.contact-intro{
  font-size:15px;
  color:var(--text);
  line-height:1.8;
  margin-bottom:18px;
}
.response-pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:var(--ink);
  font-size:13px;
  font-weight:700;
}
.response-pill::before{
  content:"";
  width:10px;
  height:10px;
  border-radius:50%;
  background:#55d27a;
  box-shadow:0 0 0 8px rgba(85,210,122,.16);
}
.form-title{
  font-size:22px;
  line-height:1;
  letter-spacing:-.04em;
  margin-bottom:18px;
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.form-field{display:grid;gap:8px}
.form-field.is-full{grid-column:1/-1}
.form-label{
  font-size:13px;
  color:var(--muted);
  font-weight:650;
}
.form-label .required{color:#d86f6f}
.form-input,
.form-textarea{
  width:100%;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:var(--ink);
  font:inherit;
  padding:14px 16px;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.form-input:focus,
.form-textarea:focus{
  border-color:rgba(255,255,255,.18);
  box-shadow:0 0 0 4px rgba(255,255,255,.05);
}
.form-textarea{
  min-height:150px;
  resize:vertical;
}
.form-help{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  color:var(--ink);
  font-size:11px;
  margin-left:6px;
  cursor:help;
}
.form-upload{
  display:grid;
  gap:10px;
  padding:16px;
  border-radius:20px;
  border:1px dashed rgba(255,255,255,.14);
  background:rgba(255,255,255,.03);
  cursor:pointer;
  transition:border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.form-upload:hover{
  border-color:rgba(255,255,255,.22);
  background:rgba(255,255,255,.04);
}
.form-upload:focus-within{
  border-color:rgba(255,255,255,.24);
  box-shadow:0 0 0 4px rgba(255,255,255,.04);
}
.form-upload.is-invalid{
  border-color:rgba(216,111,111,.72);
  background:rgba(216,111,111,.08);
  box-shadow:0 0 0 4px rgba(216,111,111,.08);
}
.form-upload-input{
  position:absolute;
  width:1px;
  height:1px;
  margin:-1px;
  padding:0;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}
.form-upload-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  min-height:40px;
  padding:0 16px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:var(--ink);
  font-size:13px;
  font-weight:750;
  letter-spacing:-.02em;
}
.form-upload-copy{
  color:var(--muted);
  font-size:13px;
  line-height:1.65;
}
.form-upload-copy.is-error{
  color:#ffb0b0;
}
.form-upload-meta{
  color:var(--text);
  font-size:12px;
  line-height:1.5;
}
.form-upload-meta.is-error{
  color:#ffb0b0;
}
.form-upload-error{
  display:none;
  font-size:12px;
  line-height:1.5;
  color:#ffb0b0;
}
.form-upload-error.is-visible{
  display:block;
}
.form-check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
}
.form-check input{margin-top:3px}
.form-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-top:18px;
}
.form-submit{
  min-height:50px;
  padding:0 22px;
  border:none;
  border-radius:999px;
  background:var(--btn);
  color:var(--btn-text);
  font:inherit;
  font-size:14px;
  font-weight:800;
  cursor:pointer;
}
.form-submit:disabled{
  opacity:.66;
  cursor:wait;
}
.form-note{
  font-size:13px;
  color:var(--muted);
}
.form-status{
  display:none;
  margin-top:12px;
  font-size:13px;
  line-height:1.6;
}
.form-status.is-visible{display:block}
.form-status.is-error{color:#ffb0b0}
.form-status.is-success{color:#d2d8cf}
.form-success{
  display:none;
  padding:20px 0 4px;
}
.form-success.is-visible{display:block}
.form-success h3{
  font-size:24px;
  line-height:1;
  letter-spacing:-.04em;
  margin-bottom:10px;
}
.form-success p{
  color:var(--text);
  font-size:14px;
  line-height:1.8;
}
.map-card{
  margin-top:18px;
  border-radius:30px;
  background:var(--surface);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.map-split{
  display:grid;
  grid-template-columns:minmax(280px,.78fr) minmax(0,1.22fr);
  align-items:stretch;
}
.map-info{
  padding:28px;
}
.map-info p{
  font-size:14px;
  color:var(--text);
  line-height:1.8;
}
.map-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:20px;
}
.map-route{
  min-height:48px;
  padding:0 20px;
  border-radius:999px;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  font-weight:750;
  letter-spacing:-.02em;
  background:var(--btn);
  color:var(--btn-text);
}
.map-frame{
  min-height:380px;
  position:relative;
}
.map-frame iframe{
  width:100%;
  height:100%;
  min-height:380px;
  border:0;
  display:block;
}
.map-consent-placeholder{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:28px;
  text-align:center;
  background:
    radial-gradient(circle at top, rgba(198,163,109,.08), transparent 34%),
    linear-gradient(180deg, rgba(15,16,18,.96), rgba(11,12,15,.98));
  color:var(--ink);
}
.map-consent-placeholder strong{
  font-size:20px;
  line-height:1.2;
  letter-spacing:-.03em;
}
.map-consent-placeholder p{
  max-width:36ch;
  color:var(--text);
  font-size:14px;
  line-height:1.72;
}
.map-consent-btn{
  min-height:48px;
  padding:0 20px;
  border-radius:999px;
  border:1px solid transparent;
  background:var(--btn);
  color:var(--btn-text);
  font:700 14px/1 'Geist',system-ui,-apple-system,sans-serif;
  cursor:pointer;
}
.form-error .form-input:invalid,
.form-error .form-textarea:invalid,
.form-check.is-invalid{
  border-color:rgba(216,111,111,.9);
  box-shadow:0 0 0 4px rgba(216,111,111,.10);
}
.form-error .form-field:has(.form-input:invalid) .form-label,
.form-error .form-field:has(.form-textarea:invalid) .form-label,
.form-error .form-check.is-invalid{
  color:#efb0b0;
}

@media(max-width:980px){
  .topbar{width:min(calc(100% - 18px), 1380px);grid-template-columns:1fr;justify-items:stretch}
  .topbar-center,
  .topbar-actions{justify-content:flex-start}
  .content-grid,
  .contact-layout,
  .map-split{grid-template-columns:1fr}
  .side-card{position:static}
}
@media(max-width:768px){
  .page{width:calc(100% - 12px);padding:12px 0 44px}
  .hero{padding:24px;border-radius:28px}
  .hero::after{
    right:-16%;
    top:58%;
    width:min(82vw, 420px);
    transform:translateY(-50%) rotate(-14deg);
    opacity:.07;
  }
  .content-card,.side-card,.contact-panel,.contact-form-panel{padding:24px 20px;border-radius:24px}
  .topbar{width:min(calc(100% - 12px), 1380px);padding:8px;gap:10px;grid-template-columns:minmax(0,1fr) auto}
  .topbar-center,
  .topbar-actions{display:none}
  .topbar-mobile-toggle{display:flex}
  .brand{min-height:62px}
  .brand-icon{width:58px;height:58px;border-radius:16px}
  .brand-name{font-size:18px}
  .brand-tagline{font-size:11px}
  .topbar-nav{padding:4px}
  .topbar-nav a{min-height:38px;padding:0 14px;font-size:13px}
  .section-title,.side-title,.form-title{font-size:24px}
  .form-grid{grid-template-columns:1fr}
  .form-actions{flex-direction:column;align-items:stretch}
  .form-upload{padding:14px;border-radius:18px}
  .form-upload-cta{width:100%}
  .map-info{padding:24px 20px}
  .map-frame,
  .map-frame iframe{min-height:320px}
  .floating-contact{right:12px;bottom:12px;min-height:50px;padding:0 16px;font-size:13px}
}
