/*
Theme Name: Onyx Chauffeurservice
Theme URI: https://www.onyx-chauffeurservice.de
Author: Specht GmbH
Author URI: https://timespecht.de
Description: Premium-Theme fuer Onyx Chauffeurservice Muenchen. Edle Landingpage mit Buchungs-CTAs, echten Google-Bewertungen und im Backend editierbaren Inhalten (Customizer). Erstellt von der Specht GmbH.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: onyx
*/


  :root{
    --onyx:#0b0c0e;
    --onyx-soft:#14161a;
    --onyx-card:#1b1e23;
    --ink:#0b0c0e;
    --champ:#c9a25e;        /* warmes Champagner-Gold */
    --champ-bright:#e0bd78;
    --champ-deep:#a47e3f;
    --line:rgba(201,162,94,.22);
    --line-soft:rgba(255,255,255,.08);
    --paper:#f6f3ee;
    --paper-2:#ece6db;
    --text-dim:#9aa0a8;
    --text-mid:#c5c9cf;
    --white:#f7f5f1;
    --r:14px;
    --maxw:1180px;
    --ease:cubic-bezier(.4,.05,.15,1);
  }

  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:'Inter',system-ui,sans-serif;
    background:var(--onyx);
    color:var(--white);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  h1,h2,h3,.serif{font-family:'Fraunces',Georgia,serif;font-weight:400;letter-spacing:-.01em;line-height:1.08}
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}

  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .eyebrow{
    font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;
    color:var(--champ);font-weight:600;display:inline-flex;align-items:center;gap:12px;
  }
  .eyebrow::before{content:"";width:28px;height:1px;background:var(--champ);display:inline-block}

  /* ---------- BUTTONS ---------- */
  .btn{
    display:inline-flex;align-items:center;justify-content:center;gap:10px;
    font-family:'Inter',sans-serif;font-weight:600;font-size:.95rem;
    padding:15px 28px;border-radius:100px;cursor:pointer;border:none;
    transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
    white-space:nowrap;letter-spacing:.01em;
  }
  .btn-gold{
    background:linear-gradient(135deg,var(--champ-bright),var(--champ-deep));
    color:#1a1206;box-shadow:0 8px 28px rgba(201,162,94,.32);
  }
  .btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 38px rgba(201,162,94,.45)}
  .btn-ghost{
    background:transparent;color:var(--white);border:1px solid var(--line);
  }
  .btn-ghost:hover{border-color:var(--champ);background:rgba(201,162,94,.08);transform:translateY(-2px)}
  .btn-dark{background:var(--onyx);color:var(--white)}
  .btn-dark:hover{transform:translateY(-2px)}
  .btn svg{width:18px;height:18px}

  /* ---------- TOP CALL BAR (sticky) ---------- */
  .callbar{
    position:fixed;top:0;left:0;right:0;z-index:90;
    background:rgba(11,12,14,.82);backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line-soft);
    transition:transform .4s var(--ease);
  }
  .callbar.hide{transform:translateY(-100%)}
  .callbar-inner{max-width:var(--maxw);margin:0 auto;padding:11px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px}
  .brand{font-family:'Fraunces';font-size:1.5rem;letter-spacing:.16em;font-weight:500;color:var(--white)}
  .brand span{color:var(--champ)}
  .callbar-actions{display:flex;align-items:center;gap:14px}
  .callbar-phone{
    display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;color:var(--white);
    transition:color .2s;
  }
  .callbar-phone:hover{color:var(--champ-bright)}
  .callbar-phone svg{width:17px;height:17px;color:var(--champ)}
  .callbar .btn{padding:11px 22px;font-size:.88rem}

  /* ---------- HERO ---------- */
  .hero{
    position:relative;min-height:100vh;display:flex;align-items:center;
    padding:120px 0 200px;overflow:hidden;
  }
  .hero-bg{
    position:absolute;inset:0;z-index:0;
    background:
      radial-gradient(120% 90% at 75% 15%,rgba(201,162,94,.10),transparent 55%),
      linear-gradient(180deg,#0b0c0e 0%,#0e0f12 50%,#0b0c0e 100%);
  }
  /* meißel-bänder: anspielung auf den onyx-stein */
  .hero-bands{position:absolute;inset:0;z-index:0;opacity:.5;overflow:hidden}
  .band{position:absolute;height:1px;width:140%;left:-20%;background:linear-gradient(90deg,transparent,var(--champ),transparent);opacity:.10}
  .band:nth-child(1){top:22%;transform:rotate(-8deg)}
  .band:nth-child(2){top:46%;transform:rotate(-8deg)}
  .band:nth-child(3){top:68%;transform:rotate(-8deg)}
  .band:nth-child(4){top:84%;transform:rotate(-8deg)}

  .hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center;width:100%}
  .hero-copy{max-width:620px}
  .hero h1{
    font-size:clamp(2.7rem,5.6vw,4.6rem);margin:24px 0 22px;font-weight:400;
    color:var(--white);
  }
  .hero h1 em{font-style:italic;color:var(--champ-bright);font-weight:400}
  .hero-lead{font-size:1.18rem;color:var(--text-mid);max-width:540px;font-weight:300;line-height:1.7}
  .hero-cta-row{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap}
  .hero-meta{display:flex;gap:34px;margin-top:46px;flex-wrap:wrap}
  .hero-meta div{display:flex;flex-direction:column}
  .hero-meta .num{font-family:'Fraunces';font-size:2rem;color:var(--champ-bright);line-height:1}
  .hero-meta .lbl{font-size:.78rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin-top:8px}

  /* booking card in hero */
  .book-card{
    background:linear-gradient(165deg,rgba(27,30,35,.96),rgba(17,19,23,.96));
    border:1px solid var(--line);border-radius:20px;padding:32px;
    box-shadow:0 30px 80px rgba(0,0,0,.5);backdrop-filter:blur(6px);
  }
  .book-card h3{font-size:1.4rem;color:var(--white);margin-bottom:6px}
  .book-card .sub{font-size:.9rem;color:var(--text-dim);margin-bottom:24px}
  .field{margin-bottom:14px}
  .field label{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-bottom:7px}
  .field input,.field select{
    width:100%;padding:13px 15px;background:rgba(255,255,255,.04);
    border:1px solid var(--line-soft);border-radius:10px;color:var(--white);
    font-family:'Inter';font-size:.95rem;transition:border .2s,background .2s;
  }
  .field input:focus,.field select:focus{outline:none;border-color:var(--champ);background:rgba(201,162,94,.06)}
  .field input::placeholder{color:#5f656d}
  .field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .book-card .btn{width:100%;margin-top:10px}
  .book-card .or-call{text-align:center;margin-top:18px;font-size:.85rem;color:var(--text-dim)}
  .book-card .or-call a{color:var(--champ-bright);font-weight:600}

  /* ---------- TRUST STRIP ---------- */
  .trust-strip{
    position:relative;z-index:3;margin-top:-110px;
  }
  .trust-strip .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
    background:var(--line-soft);border:1px solid var(--line-soft);border-radius:var(--r);overflow:hidden}
  .trust-item{background:var(--onyx-soft);padding:30px 26px;text-align:center}
  .trust-item .ico{width:30px;height:30px;margin:0 auto 14px;color:var(--champ)}
  .trust-item .t{font-family:'Fraunces';font-size:1.15rem;color:var(--white);margin-bottom:5px}
  .trust-item .d{font-size:.84rem;color:var(--text-dim);line-height:1.5}

  /* ---------- SECTIONS ---------- */
  section{position:relative}
  .pad{padding:110px 0}
  .pad-sm{padding:80px 0}
  .section-head{max-width:620px;margin-bottom:56px}
  .section-head.center{margin-left:auto;margin-right:auto;text-align:center}
  .section-head h2{font-size:clamp(2rem,3.8vw,3rem);margin:18px 0 18px;color:var(--white)}
  .section-head p{color:var(--text-mid);font-size:1.08rem;font-weight:300}

  /* services */
  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .svc{
    background:var(--onyx-card);border:1px solid var(--line-soft);border-radius:var(--r);
    padding:38px 32px;transition:transform .35s var(--ease),border-color .35s;
    position:relative;overflow:hidden;
  }
  .svc::after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--champ-deep),var(--champ-bright));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
  .svc:hover{transform:translateY(-6px);border-color:var(--line)}
  .svc:hover::after{transform:scaleX(1)}
  .svc .svc-ico{width:42px;height:42px;color:var(--champ);margin-bottom:22px}
  .svc h3{font-size:1.5rem;color:var(--white);margin-bottom:12px}
  .svc p{color:var(--text-dim);font-size:.96rem;line-height:1.65;margin-bottom:20px}
  .svc .lk{display:inline-flex;align-items:center;gap:8px;color:var(--champ-bright);font-weight:600;font-size:.9rem}
  .svc .lk svg{width:16px;height:16px;transition:transform .25s}
  .svc:hover .lk svg{transform:translateX(4px)}

  /* fleet */
  .fleet{background:var(--onyx-soft)}
  .fleet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .car{
    background:linear-gradient(180deg,var(--onyx-card),#16181c);
    border:1px solid var(--line-soft);border-radius:var(--r);overflow:hidden;
    transition:transform .35s var(--ease),border-color .35s;
  }
  .car:hover{transform:translateY(-6px);border-color:var(--line)}
  .car-vis{height:170px;display:flex;align-items:center;justify-content:center;
    background:radial-gradient(circle at 50% 120%,rgba(201,162,94,.14),transparent 70%);position:relative}
  .car-vis svg{width:78%;height:auto;color:#2a2d33;filter:drop-shadow(0 10px 20px rgba(0,0,0,.4))}
  .car-body{padding:28px 28px 32px}
  .car-tier{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--champ);font-weight:600}
  .car-body h3{font-size:1.45rem;color:var(--white);margin:8px 0 6px}
  .car-body .seats{font-size:.88rem;color:var(--text-dim);margin-bottom:18px;display:flex;gap:18px}
  .car-body .seats span{display:inline-flex;align-items:center;gap:6px}
  .car-body .seats svg{width:15px;height:15px;color:var(--champ)}
  .car-body p{font-size:.92rem;color:var(--text-mid);line-height:1.6;margin-bottom:20px}
  .car .btn{width:100%}

  /* split feature */
  .split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  .split.rev .split-vis{order:2}
  .split-vis{border-radius:18px;overflow:hidden;position:relative;min-height:420px;
    border:1px solid var(--line)}
  .split-vis .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    background:
      radial-gradient(circle at 30% 25%,rgba(201,162,94,.07),transparent 55%),
      radial-gradient(circle at 70% 90%,#1c1f24,#0c0d10);}
  .split-vis .ph::before{content:"";position:absolute;inset:0;
    background-image:repeating-linear-gradient(115deg,transparent 0 38px,rgba(201,162,94,.04) 38px 39px);}
  .split-vis .ph svg{width:54%;color:#2b2e34;position:relative;z-index:1;filter:drop-shadow(0 18px 30px rgba(0,0,0,.5))}
  .split-vis .badge{position:absolute;bottom:24px;left:24px;right:24px;
    background:rgba(11,12,14,.78);backdrop-filter:blur(10px);border:1px solid var(--line);
    border-radius:12px;padding:18px 22px;display:flex;align-items:center;gap:16px}
  .split-vis .badge .bnum{font-family:'Fraunces';font-size:2rem;color:var(--champ-bright);line-height:1}
  .split-vis .badge .btxt{font-size:.86rem;color:var(--text-mid)}
  .split-copy h2{font-size:clamp(1.9rem,3.4vw,2.7rem);color:var(--white);margin:18px 0 22px}
  .split-copy p{color:var(--text-mid);font-size:1.05rem;margin-bottom:18px;font-weight:300;line-height:1.75}
  .split-copy .checks{list-style:none;margin:26px 0 32px}
  .split-copy .checks li{display:flex;align-items:flex-start;gap:13px;margin-bottom:14px;color:var(--text-mid);font-size:.98rem}
  .split-copy .checks svg{width:21px;height:21px;color:var(--champ);flex-shrink:0;margin-top:2px}

  /* process / how it works */
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;counter-reset:step}
  .step{position:relative;padding-top:18px}
  .step .snum{font-family:'Fraunces';font-size:3.4rem;color:var(--champ);opacity:.32;line-height:1;font-weight:300}
  .step h3{font-size:1.3rem;color:var(--white);margin:10px 0 10px}
  .step p{color:var(--text-dim);font-size:.95rem;line-height:1.6}
  .step::before{content:"";position:absolute;top:30px;left:64px;right:-15px;height:1px;
    background:linear-gradient(90deg,var(--line),transparent)}
  .step:last-child::before{display:none}

  /* reviews */
  .reviews{background:var(--onyx-soft)}
  .rev-top{display:flex;align-items:center;justify-content:space-between;gap:30px;margin-bottom:48px;flex-wrap:wrap}
  .rev-score{display:flex;align-items:center;gap:22px}
  .rev-score .big{font-family:'Fraunces';font-size:3.6rem;color:var(--champ-bright);line-height:1}
  .rev-stars{color:var(--champ-bright);font-size:1.25rem;letter-spacing:3px}
  .rev-score .meta{font-size:.9rem;color:var(--text-dim);margin-top:4px}
  .rev-google{display:inline-flex;align-items:center;gap:10px;font-size:.9rem;color:var(--text-mid);
    border:1px solid var(--line-soft);padding:10px 18px;border-radius:100px}
  .rev-google b{color:var(--white)}
  .rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .rev{background:var(--onyx-card);border:1px solid var(--line-soft);border-radius:var(--r);padding:28px;
    display:flex;flex-direction:column;gap:14px;transition:border-color .3s}
  .rev:hover{border-color:var(--line)}
  .rev .stars{color:var(--champ-bright);letter-spacing:2px;font-size:.95rem}
  .rev .txt{color:var(--text-mid);font-size:.95rem;line-height:1.65;flex-grow:1}
  .rev .who{display:flex;align-items:center;gap:12px;margin-top:6px}
  .rev .av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--champ-deep),var(--champ-bright));
    display:flex;align-items:center;justify-content:center;font-family:'Fraunces';color:#1a1206;font-size:1.05rem;flex-shrink:0}
  .rev .who .nm{font-weight:600;font-size:.92rem;color:var(--white)}
  .rev .who .dt{font-size:.78rem;color:var(--text-dim)}
  .rev .gicon{width:16px;height:16px;margin-left:auto;flex-shrink:0}

  /* CTA band */
  .cta-band{position:relative;overflow:hidden;
    background:linear-gradient(135deg,#15110a,#0b0c0e 60%);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .cta-band .glow{position:absolute;top:-40%;right:-10%;width:600px;height:600px;
    background:radial-gradient(circle,rgba(201,162,94,.16),transparent 65%);pointer-events:none}
  .cta-inner{position:relative;z-index:2;text-align:center;max-width:720px;margin:0 auto}
  .cta-inner h2{font-size:clamp(2.1rem,4vw,3.2rem);color:var(--white);margin:18px 0 20px}
  .cta-inner p{color:var(--text-mid);font-size:1.1rem;margin-bottom:34px;font-weight:300}
  .cta-inner .row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

  /* extras / why bar */
  .why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .why{text-align:center;padding:34px 26px;border:1px solid var(--line-soft);border-radius:var(--r);
    background:var(--onyx-card);transition:transform .3s,border-color .3s}
  .why:hover{transform:translateY(-4px);border-color:var(--line)}
  .why .ico{width:38px;height:38px;color:var(--champ);margin:0 auto 18px}
  .why h3{font-size:1.25rem;color:var(--white);margin-bottom:10px}
  .why p{color:var(--text-dim);font-size:.92rem;line-height:1.6}

  /* areas served */
  .areas{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px}
  .area-chip{border:1px solid var(--line-soft);padding:11px 22px;border-radius:100px;font-size:.9rem;
    color:var(--text-mid);transition:all .25s}
  .area-chip:hover{border-color:var(--champ);color:var(--champ-bright);background:rgba(201,162,94,.06)}

  /* FAQ */
  .faq-wrap{max-width:820px;margin:0 auto}
  .faq{border-bottom:1px solid var(--line-soft)}
  .faq-q{width:100%;background:none;border:none;cursor:pointer;text-align:left;
    padding:26px 0;display:flex;align-items:center;justify-content:space-between;gap:20px;
    font-family:'Fraunces';font-size:1.22rem;color:var(--white)}
  .faq-q .pm{width:24px;height:24px;flex-shrink:0;color:var(--champ);transition:transform .3s}
  .faq.open .faq-q .pm{transform:rotate(45deg)}
  .faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
  .faq-a-inner{padding:0 0 26px;color:var(--text-mid);font-size:1rem;line-height:1.7;font-weight:300;max-width:90%}

  /* contact */
  .contact{background:var(--onyx-soft)}
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
  .ct-line{display:flex;gap:18px;padding:24px 0;border-bottom:1px solid var(--line-soft)}
  .ct-line .ico{width:40px;height:40px;border-radius:10px;background:rgba(201,162,94,.1);
    border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--champ)}
  .ct-line .ico svg{width:19px;height:19px}
  .ct-line h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim);margin-bottom:5px}
  .ct-line .v{font-size:1.1rem;color:var(--white);font-weight:500}
  .ct-line .v a:hover{color:var(--champ-bright)}
  .ct-line .sub{font-size:.85rem;color:var(--text-dim);margin-top:4px}
  .ct-form{background:var(--onyx-card);border:1px solid var(--line);border-radius:18px;padding:36px}
  .ct-form h3{font-size:1.5rem;color:var(--white);margin-bottom:8px}
  .ct-form .sub{color:var(--text-dim);font-size:.92rem;margin-bottom:26px}
  .ct-form .btn{width:100%;margin-top:8px}

  /* footer */
  footer{background:var(--onyx);border-top:1px solid var(--line-soft);padding:70px 0 30px}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
  .foot-brand .brand{font-size:1.9rem;margin-bottom:16px;display:inline-block}
  .foot-brand p{color:var(--text-dim);font-size:.92rem;max-width:280px;line-height:1.6}
  .foot-soc{display:flex;gap:12px;margin-top:22px}
  .foot-soc a{width:40px;height:40px;border:1px solid var(--line-soft);border-radius:50%;
    display:flex;align-items:center;justify-content:center;color:var(--text-mid);transition:all .25s}
  .foot-soc a:hover{border-color:var(--champ);color:var(--champ-bright);transform:translateY(-3px)}
  .foot-soc svg{width:17px;height:17px}
  .foot-col h5{font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--champ);margin-bottom:20px;font-weight:600}
  .foot-col a{display:block;color:var(--text-dim);font-size:.92rem;padding:7px 0;transition:color .2s}
  .foot-col a:hover{color:var(--white)}
  .foot-bottom{border-top:1px solid var(--line-soft);padding-top:26px;display:flex;
    justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;
    font-size:.84rem;color:var(--text-dim)}
  .foot-bottom .legal{display:flex;gap:22px}
  .foot-bottom .legal a:hover{color:var(--white)}

  /* mobile sticky CTA */
  .mobile-cta{
    display:none;position:fixed;bottom:0;left:0;right:0;z-index:95;
    background:rgba(11,12,14,.94);backdrop-filter:blur(14px);
    border-top:1px solid var(--line);padding:12px 16px;gap:10px;
  }
  .mobile-cta .btn{flex:1;padding:14px;font-size:.9rem}

  /* reveal animation */
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  .reveal.in{opacity:1;transform:none}

  /* ---------- RESPONSIVE ---------- */
  @media(max-width:980px){
    .hero-inner{grid-template-columns:1fr;gap:44px}
    .hero{padding:110px 0 160px;min-height:auto}
    .book-card{max-width:460px}
    .trust-strip .wrap{grid-template-columns:1fr 1fr}
    .svc-grid,.fleet-grid,.rev-grid,.steps,.why-grid{grid-template-columns:1fr 1fr}
    .split{grid-template-columns:1fr;gap:36px}
    .split.rev .split-vis{order:0}
    .contact-grid{grid-template-columns:1fr;gap:36px}
    .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
    .step::before{display:none}
  }
  @media(max-width:640px){
    .wrap{padding:0 18px}
    .callbar-actions .btn{display:none}
    .callbar .callbar-phone span.txt{display:none}
    .hero h1{font-size:2.5rem}
    .hero-meta{gap:24px}
    .trust-strip .wrap{grid-template-columns:1fr}
    .svc-grid,.fleet-grid,.rev-grid,.steps,.why-grid,.foot-grid{grid-template-columns:1fr}
    .pad{padding:72px 0}
    .rev-grid .rev:nth-child(n+4){display:none}
    .mobile-cta{display:flex}
    body{padding-bottom:72px}
    .foot-bottom{flex-direction:column;text-align:center}
    .book-card{padding:26px 22px}
    .field-row{grid-template-columns:1fr}
  }
