/*
Theme Name: Fasola AG
Theme URI: https://fasola-ag.ch
Author: Fasola AG
Description: Out-of-Home Plakatwerbung Tessin - Theme nach Prototyp (Phase 2 / Meilenstein 1). Marketingseite + Buchungs-Wizard-Frontend.
Version: 0.1.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: fasola
*/

:root{
  --blau:#000033;        /* dunkelblau Wappen */
  --blau-80:#1a1a4d;
  --blau-60:#33336b;
  --orange:#ff6600;      /* hover / aktiv */
  --gold:#ffba42;        /* akzent */
  --weiss:#ffffff;
  --grau-bg:#f5f6f8;
  --grau-line:#e3e6ec;
  --grau-text:#5a6072;
  --gruen:#1f9d5a;
  --rot:#c8372d;
  --schatten:0 2px 14px rgba(0,0,20,.08);
  --schatten-lg:0 10px 40px rgba(0,0,40,.16);
  --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter','Segoe UI',-apple-system,system-ui,Helvetica,Arial,sans-serif;
  color:#16182a;background:var(--weiss);line-height:1.55;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{line-height:1.18;letter-spacing:-.01em;color:var(--blau)}
h1{font-size:clamp(2rem,4.4vw,3.3rem);font-weight:800}
h2{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800}
h3{font-size:1.18rem;font-weight:700}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
.muted{color:var(--grau-text)}
.center{text-align:center}
.pill{display:inline-block;padding:5px 12px;border-radius:999px;font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.btn{cursor:pointer;border:none;font:inherit;font-weight:700;padding:13px 24px;border-radius:10px;transition:.18s;display:inline-flex;align-items:center;gap:9px}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:#e85c00;transform:translateY(-1px)}
.btn-dark{background:var(--blau);color:#fff}
.btn-dark:hover{background:var(--blau-60)}
.btn-ghost{background:transparent;color:var(--blau);border:1.5px solid var(--grau-line)}
.btn-ghost:hover{border-color:var(--blau);background:#fafbff}
.btn-sm{padding:8px 15px;font-size:.85rem;border-radius:8px}
.btn[disabled]{opacity:.4;cursor:not-allowed;transform:none}

/* ---------- HEADER ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--grau-line)}
.nav{display:flex;align-items:center;gap:26px;height:72px}
.brand{display:flex;align-items:center;gap:11px}
.brand img{height:42px;width:auto}
.brand b{font-size:1.18rem;color:var(--blau);letter-spacing:.01em}
.brand span{font-size:.66rem;letter-spacing:.22em;color:var(--grau-text);display:block;text-transform:uppercase;margin-top:1px}
.nav-links{display:flex;gap:6px;margin-left:auto}
.nav-links a{padding:9px 14px;border-radius:8px;font-weight:600;font-size:.95rem;color:var(--blau-80);transition:.15s}
.nav-links a:hover{background:#fff3eb;color:var(--orange)}
.nav-right{display:flex;align-items:center;gap:10px}
.lang{display:flex;gap:2px;font-size:.8rem;font-weight:700}
.lang button{background:none;border:none;cursor:pointer;color:var(--grau-text);padding:4px 6px;border-radius:6px}
.lang button.on{color:var(--blau);background:var(--grau-bg)}
.burger{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--blau)}
@media(max-width:900px){.nav-links{display:none}.burger{display:block}}

/* ---------- HERO ---------- */
.hero{position:relative;background:linear-gradient(120deg,#000033 0%,#1a1a52 55%,#2a2a6e 100%);color:#fff;overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-80px;width:520px;height:520px;background:radial-gradient(circle,rgba(255,186,66,.22),transparent 60%);}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding:64px 0 72px}
.hero h1{color:#fff}
.hero h1 em{color:var(--gold);font-style:normal}
.hero p.lead{font-size:1.15rem;color:#d4d8ee;margin:18px 0 26px;max-width:33em}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-points{display:flex;gap:22px;margin-top:30px;flex-wrap:wrap}
.hero-points div{font-size:.86rem;color:#cdd2ec}
.hero-points b{display:block;color:var(--gold);font-size:1.5rem;font-weight:800}
/* hero quick-booking card */
.qb{background:#fff;color:#16182a;border-radius:var(--radius);box-shadow:var(--schatten-lg);padding:22px}
.qb h3{margin-bottom:4px}
.qb .field{margin-top:14px}
.qb label{font-size:.78rem;font-weight:700;color:var(--blau-80);text-transform:uppercase;letter-spacing:.03em}
.qb select,.qb input{width:100%;margin-top:6px;padding:11px 12px;border:1.5px solid var(--grau-line);border-radius:9px;font:inherit;background:#fff}
.qb select:focus,.qb input:focus{outline:none;border-color:var(--orange)}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:28px;padding:42px 0 50px}}

/* ---------- SECTIONS ---------- */
section{padding:68px 0}
.sec-head{max-width:46em;margin:0 auto 42px;text-align:center}
.sec-head .pill{background:#fff3eb;color:var(--orange);margin-bottom:14px}
.sec-head p{color:var(--grau-text);margin-top:12px;font-size:1.05rem}
.alt{background:var(--grau-bg)}

/* formats */
.formats{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.fmt{background:#fff;border:1px solid var(--grau-line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--schatten);display:flex;flex-direction:column}
.fmt .visual{height:190px;display:flex;align-items:center;justify-content:center;position:relative}
.fmt.f24 .visual{background:linear-gradient(135deg,#eef1f8,#dfe4f2)}
.fmt.gf .visual{background:linear-gradient(135deg,#000033,#33336b)}
.board{background:#fff;border:3px solid var(--blau);border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--blau);box-shadow:0 6px 18px rgba(0,0,40,.2)}
.fmt.f24 .board{width:150px;height:75px;font-size:.8rem}
.fmt.gf .board{width:130px;height:104px;font-size:.8rem;border-color:var(--gold);color:var(--blau);position:relative}
.fmt.gf .board::after{content:"";position:absolute;inset:-3px -3px auto;height:8px;top:-13px;background:var(--gold);border-radius:4px;box-shadow:0 0 18px 4px rgba(255,186,66,.7)}
.fmt-body{padding:22px 22px 24px;flex:1;display:flex;flex-direction:column}
.fmt-body h3{display:flex;align-items:center;gap:9px}
.fmt-tag{font-size:.7rem;font-weight:800;padding:3px 9px;border-radius:6px;background:var(--blau);color:#fff}
.fmt.gf .fmt-tag{background:var(--gold);color:var(--blau)}
.spec{list-style:none;margin:14px 0 18px;font-size:.93rem}
.spec li{padding:7px 0;border-bottom:1px dashed var(--grau-line);display:flex;justify-content:space-between;gap:14px}
.spec li span:first-child{color:var(--grau-text)}
.spec li b{color:var(--blau);text-align:right}
.fmt .price{font-size:1.5rem;font-weight:800;color:var(--blau);margin-top:auto}
.fmt .price small{font-size:.8rem;color:var(--grau-text);font-weight:600}
@media(max-width:760px){.formats{grid-template-columns:1fr}}

/* USP */
.usps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.usp{background:#fff;border-radius:var(--radius);padding:24px;border:1px solid var(--grau-line)}
.usp .ic{width:46px;height:46px;border-radius:12px;background:#fff3eb;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:14px}
.usp h3{font-size:1.04rem;margin-bottom:6px}
.usp p{font-size:.9rem;color:var(--grau-text)}
@media(max-width:880px){.usps{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.usps{grid-template-columns:1fr}}

/* MAP + locations */
.map-layout{display:grid;grid-template-columns:1.25fr .9fr;gap:24px;align-items:stretch}
.map-box{background:#eef1f6;border:1px solid var(--grau-line);border-radius:var(--radius);overflow:hidden;position:relative;min-height:440px}
.map-svg{width:100%;height:100%;display:block}
.pin{cursor:pointer;transition:.15s}
.pin:hover{transform:translateY(-2px)}
.pin circle.dot{fill:var(--orange);stroke:#fff;stroke-width:2.5}
.pin.gf circle.dot{fill:var(--gold)}
.pin.sel circle.dot{fill:var(--blau)}
.pin text{font-size:9px;font-weight:800;fill:#fff;text-anchor:middle;dominant-baseline:central;pointer-events:none}
.maplegend{position:absolute;left:14px;bottom:14px;background:rgba(255,255,255,.94);border-radius:10px;padding:10px 12px;font-size:.76rem;box-shadow:var(--schatten)}
.maplegend div{display:flex;align-items:center;gap:7px;margin:3px 0}
.maplegend i{width:12px;height:12px;border-radius:50%;display:inline-block}
.loc-list{display:flex;flex-direction:column;gap:11px;max-height:440px;overflow:auto;padding-right:4px}
.loc-card{border:1.5px solid var(--grau-line);border-radius:12px;padding:14px 15px;cursor:pointer;transition:.15s;background:#fff}
.loc-card:hover{border-color:var(--orange);box-shadow:var(--schatten)}
.loc-card.active{border-color:var(--blau);background:#fafbff}
.loc-card .top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.loc-card h4{font-size:1rem;color:var(--blau)}
.loc-card .addr{font-size:.84rem;color:var(--grau-text)}
.badge{font-size:.66rem;font-weight:800;padding:3px 8px;border-radius:6px;white-space:nowrap}
.badge.f24{background:#e9edf9;color:var(--blau)}
.badge.gf{background:#fff2d6;color:#8a6300}
.loc-meta{display:flex;gap:14px;margin-top:9px;font-size:.78rem;color:var(--grau-text);flex-wrap:wrap}
.loc-meta b{color:var(--blau)}
@media(max-width:860px){.map-layout{grid-template-columns:1fr}.map-box{min-height:320px}}

/* steps how it works */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:s}
.step{position:relative;padding:26px 18px 22px;background:#fff;border:1px solid var(--grau-line);border-radius:var(--radius)}
.step .n{counter-increment:s;width:38px;height:38px;border-radius:50%;background:var(--blau);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:13px}
.step .n::before{content:counter(s)}
.step h3{font-size:1.02rem;margin-bottom:5px}
.step p{font-size:.88rem;color:var(--grau-text)}
@media(max-width:880px){.steps{grid-template-columns:1fr 1fr}}

/* ---------- MODAL / WIZARD ---------- */
.overlay{position:fixed;inset:0;background:rgba(8,8,30,.55);backdrop-filter:blur(3px);z-index:100;display:none;align-items:flex-start;justify-content:center;padding:28px 16px;overflow:auto}
.overlay.open{display:flex}
.modal{background:#fff;border-radius:18px;width:100%;max-width:860px;box-shadow:var(--schatten-lg);overflow:hidden;animation:pop .25s}
.modal.sm{max-width:440px}
@keyframes pop{from{transform:translateY(14px);opacity:0}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--grau-line)}
.modal-head h3{font-size:1.2rem}
.x{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--grau-text);line-height:1}
.modal-body{padding:24px}
/* stepper */
.stepper{display:flex;gap:6px;padding:0 24px 4px;margin-top:16px}
.stepper .s{flex:1;text-align:center;font-size:.72rem;font-weight:700;color:var(--grau-text);position:relative;padding-bottom:14px}
.stepper .s::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;border-radius:3px;background:var(--grau-line)}
.stepper .s.done::after{background:var(--gruen)}
.stepper .s.cur::after{background:var(--orange)}
.stepper .s.cur{color:var(--orange)}
.wz-step{display:none}
.wz-step.show{display:block}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.8rem;font-weight:700;color:var(--blau-80);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:11px 12px;border:1.5px solid var(--grau-line);border-radius:9px;font:inherit;background:#fff}
.field input:focus,.field select:focus{outline:none;border-color:var(--orange)}
.hint{font-size:.78rem;color:var(--grau-text);margin-top:5px}
.pickrow{display:flex;align-items:center;gap:12px;border:1.5px solid var(--grau-line);border-radius:11px;padding:12px 14px;margin-bottom:10px;cursor:pointer;transition:.12s}
.pickrow:hover{border-color:var(--orange)}
.pickrow.on{border-color:var(--blau);background:#fafbff}
.pickrow input{width:18px;height:18px;accent-color:var(--orange)}
.pickrow .pr-main{flex:1}
.pickrow .pr-main b{color:var(--blau)}
.pickrow .pr-main small{display:block;color:var(--grau-text);font-size:.8rem}
.pickrow .pr-price{font-weight:800;color:var(--blau);white-space:nowrap}
/* upload */
.drop{border:2px dashed var(--grau-line);border-radius:12px;padding:30px;text-align:center;cursor:pointer;transition:.15s}
.drop:hover{border-color:var(--orange);background:#fff8f3}
.drop .ic{font-size:2rem}
.check{list-style:none;margin:16px 0 0;font-size:.9rem}
.check li{display:flex;align-items:center;gap:9px;padding:6px 0}
.check li .c{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#fff;background:var(--grau-line)}
.check li.ok .c{background:var(--gruen)}
.check li.ok{color:#16182a}
.check li.bad .c{background:var(--rot)}
.specbox{background:var(--grau-bg);border-radius:11px;padding:14px 16px;font-size:.85rem;margin-bottom:16px}
.specbox b{color:var(--blau)}
.archive{border:1.5px solid var(--gold);background:#fffaf0;border-radius:12px;padding:16px;display:flex;gap:14px;align-items:flex-start}
.archive input{width:20px;height:20px;margin-top:2px;accent-color:var(--orange)}
/* summary */
.sumtable{width:100%;border-collapse:collapse;font-size:.92rem}
.sumtable td{padding:9px 0;border-bottom:1px solid var(--grau-line)}
.sumtable tr:last-child td{border:none}
.sumtable .r{text-align:right;font-weight:700;color:var(--blau)}
.total td{font-size:1.15rem;font-weight:800;color:var(--blau);padding-top:14px}
.split{background:#eef9f1;border:1px solid #bfe6cd;border-radius:11px;padding:14px 16px;font-size:.9rem;margin-top:14px}
.split b{color:var(--gruen)}
.pay-opt{display:flex;gap:12px;margin:14px 0}
.pay-opt .po{flex:1;border:1.5px solid var(--grau-line);border-radius:11px;padding:16px;text-align:center;cursor:pointer;font-weight:700}
.pay-opt .po.on{border-color:var(--orange);background:#fff8f3}
.pay-opt .po small{display:block;font-weight:500;color:var(--grau-text);margin-top:4px}
.wz-foot{display:flex;justify-content:space-between;gap:12px;margin-top:22px;padding-top:18px;border-top:1px solid var(--grau-line)}
.banner{padding:11px 14px;border-radius:10px;font-size:.86rem;margin-bottom:14px;display:none}
.banner.show{display:block}
.banner.warn{background:#fff4e5;color:#8a5200;border:1px solid #ffd596}
.success-ic{width:74px;height:74px;border-radius:50%;background:#eef9f1;color:var(--gruen);display:flex;align-items:center;justify-content:center;font-size:2.4rem;margin:0 auto 16px}

/* ---------- DASHBOARD ---------- */
.dash-wrap{display:none}
.dash-top{background:var(--blau);color:#fff;padding:22px 0}
.dash-top .wrap{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.dash-top h2{color:#fff;margin-right:auto}
.roleswitch{display:flex;background:rgba(255,255,255,.12);border-radius:10px;padding:4px}
.roleswitch button{background:none;border:none;color:#cfd3ee;font-weight:700;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.86rem}
.roleswitch button.on{background:#fff;color:var(--blau)}
.dash-body{padding:30px 0 70px;background:var(--grau-bg);min-height:70vh}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
.kpi{background:#fff;border-radius:12px;padding:18px 20px;border:1px solid var(--grau-line)}
.kpi b{font-size:1.7rem;color:var(--blau);display:block}
.kpi span{font-size:.82rem;color:var(--grau-text)}
@media(max-width:760px){.kpis{grid-template-columns:1fr 1fr}}
.order{background:#fff;border:1px solid var(--grau-line);border-radius:14px;padding:20px 22px;margin-bottom:16px}
.order-head{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:flex-start}
.order-head h3{font-size:1.06rem}
.order-head .sub{font-size:.85rem;color:var(--grau-text);margin-top:2px}
.statuspill{font-size:.72rem;font-weight:800;padding:5px 11px;border-radius:999px}
.st-eingegangen{background:#e9edf9;color:var(--blau)}
.st-pruefung{background:#fff2d6;color:#8a6300}
.st-rutschi{background:#e7f0ff;color:#1c5bd6}
.st-druck{background:#ffe9d6;color:#9a4a00}
.st-aktiv{background:#eef9f1;color:var(--gruen)}
.st-beendet{background:#eceef2;color:#5a6072}
.st-storniert{background:#fde8e6;color:var(--rot)}
/* timeline */
.timeline{display:flex;margin:20px 0 6px;overflow:auto}
.tl{flex:1;min-width:96px;text-align:center;position:relative;font-size:.74rem;color:var(--grau-text)}
.tl::before{content:"";position:absolute;top:9px;left:-50%;width:100%;height:3px;background:var(--grau-line)}
.tl:first-child::before{display:none}
.tl .dot{width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid var(--grau-line);margin:0 auto 7px;position:relative;z-index:1}
.tl.done .dot{background:var(--gruen);border-color:var(--gruen)}
.tl.done::before{background:var(--gruen)}
.tl.cur .dot{background:var(--orange);border-color:var(--orange);box-shadow:0 0 0 5px rgba(255,102,0,.18)}
.tl.cur{color:var(--orange);font-weight:700}
.order-foot{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:center;margin-top:16px;padding-top:15px;border-top:1px solid var(--grau-line)}
.filechip{display:inline-flex;align-items:center;gap:8px;background:var(--grau-bg);border:1px solid var(--grau-line);border-radius:8px;padding:7px 12px;font-size:.84rem;font-weight:600}
.pay-state{font-size:.84rem}
.pay-state .dotp{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px}
footer{background:var(--blau);color:#c9cde6;padding:50px 0 26px;font-size:.9rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:30px}
.foot-grid h4{color:#fff;font-size:.95rem;margin-bottom:12px;letter-spacing:.04em;text-transform:uppercase}
.foot-grid a{display:block;padding:4px 0;color:#c9cde6}
.foot-grid a:hover{color:var(--gold)}
.foot-bot{border-top:1px solid #2a2a5a;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem}
.proto-note{position:fixed;bottom:14px;left:14px;z-index:90;background:var(--blau);color:#fff;font-size:.72rem;padding:7px 12px;border-radius:8px;box-shadow:var(--schatten);opacity:.92}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}.field-row{grid-template-columns:1fr}}
/* pricing packages */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pcard{border-radius:14px;overflow:hidden;border:1px solid var(--grau-line);display:flex;flex-direction:column;background:#fff;box-shadow:var(--schatten)}
.pcard .ph{padding:18px 16px;color:#fff;text-align:center;font-weight:700;line-height:1.3;font-size:1.02rem}
.pcard .ph small{display:block;font-weight:500;font-size:.8rem;opacity:.85;margin-top:3px}
.pcard .pi{background:var(--grau-bg);padding:13px 16px;font-size:.82rem;color:var(--grau-text);text-align:center}
.pcard .pi b{color:var(--blau)}
.pcard .pp{padding:15px 16px;flex:1}
.pcard .pp .lab{text-align:center;font-weight:700;color:var(--blau);font-size:.8rem;margin-bottom:8px}
.pcard .pp .row{display:flex;justify-content:space-between;align-items:baseline;font-size:.85rem;padding:7px 0;border-bottom:1px dashed var(--grau-line)}
.pcard .pp .row:last-child{border:none}
.pcard .pp .row b{color:var(--blau)}
.pcard .pp .row .d{color:var(--gruen);font-size:.72rem;font-weight:700;margin-left:5px}
.pcard .pb{padding:0 16px 16px}
.pcard .px{padding:13px 16px;border-top:3px solid var(--gold);font-size:.77rem;color:var(--grau-text);line-height:1.5}
.pcard .px b{color:var(--blau)}
.pcard .px em{color:var(--orange);font-style:italic}
@media(max-width:880px){.pgrid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.pgrid{grid-template-columns:1fr}}

/* gleich hohe Preis-Karten-Header */
.pcard .ph{min-height:104px;display:flex;flex-direction:column;justify-content:center;align-items:center}
