/*
Theme Name: MIKA Maritim
Theme URI: https://absolut-frei.de
Author: MIKA / Absolut-Frei Hausboote
Author URI: https://absolut-frei.de
Description: Schlankes, maritimes WordPress-Theme für Hausboot-Vercharterer. Dunkler Marineblau-Header, volle Inhaltsbreite, kein automatischer Seitentitel, kein Page-Builder-Zwang. Optimiert für das MIKA-Booking-Plugin.
Version: 1.0.9
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mika-maritim
*/

:root{
  --navy:#0a2e4d;
  --navy-deep:#072138;
  --azur:#1789c4;
  --azur-light:#3aa3da;
  --sand:#e8dcc6;
  --green:#2faa5e;
  --ink:#0d2b3e;
  --muted:#52677a;
  --paper:#fbfaf7;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Outfit',-apple-system,BlinkMacSystemFont,sans-serif;color:var(--ink);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}

/* ── TOPBAR ─────────────────────────────────────────────────── */
.thx-topbar{background:var(--navy-deep);color:rgba(255,255,255,.75);font-size:13px}
.thx-topbar-inner{max-width:1320px;margin:0 auto;padding:7px 32px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.thx-topbar a{color:rgba(255,255,255,.85)}
.thx-topbar .tb-right{display:flex;gap:18px}

/* ── HEADER ─────────────────────────────────────────────────── */
.thx-header{background:var(--navy);position:sticky;top:0;z-index:10000;box-shadow:0 2px 18px rgba(7,33,56,.25)}
.thx-header-inner{max-width:1320px;margin:0 auto;padding:0 32px;min-height:74px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.thx-logo{display:flex;align-items:center;gap:12px;padding:10px 0}
.thx-logo-mark{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--azur),var(--azur-light));display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 3px 10px rgba(23,137,196,.4);flex-shrink:0}
.thx-logo img{max-height:48px;width:auto}
.thx-logo-text{color:#fff;font-weight:700;font-size:18px;letter-spacing:.01em;line-height:1.1}
.thx-logo-text span{display:block;font-size:11px;font-weight:400;color:var(--azur-light);letter-spacing:.08em;text-transform:uppercase}
.thx-nav{display:flex;align-items:center;gap:30px}
.thx-nav>ul{display:flex;align-items:stretch;gap:10px;list-style:none}
.thx-nav ul{list-style:none}
.thx-nav a{color:rgba(255,255,255,.85);font-size:15px;font-weight:500;transition:color .15s;position:relative;padding:6px 0;display:inline-block}
.thx-nav a:hover{color:#fff}
.thx-nav .current-menu-item>a,.thx-nav .current_page_item>a{color:#fff;background:rgba(58,163,218,.26);border-color:rgba(58,163,218,.5)}
.thx-nav-cta a,a.thx-nav-cta{background:var(--green);color:#fff !important;padding:9px 20px;border-radius:9px;font-weight:600;box-shadow:0 4px 12px rgba(47,170,94,.4)}
.thx-nav-cta a:hover,a.thx-nav-cta:hover{background:#28994f}
.thx-burger{display:none;color:#fff;font-size:28px;background:none;border:none;cursor:pointer;padding:8px}

/* ── INHALTSBEREICH ─────────────────────────────────────────── */
.thx-content{min-height:420px}
.thx-content-inner{max-width:1320px;margin:0 auto;padding:48px 32px}
/* Shortcode-Seiten: volle Breite, aber dezenter seitlicher + vertikaler Rand
   (das Plugin bringt eigene max-width mit, soll aber nicht am Bildschirmrand kleben) */
.thx-content-inner.full{max-width:none;padding:32px 24px}
/* Startseite: komplett randlos, damit der Banner full-bleed über die ganze Breite geht */
.thx-content-inner.bleed{max-width:none;padding:0}

/* ── FOOTER ─────────────────────────────────────────────────── */
.thx-footer{background:var(--navy);color:rgba(255,255,255,.7)}
.thx-footer-main{max-width:1320px;margin:0 auto;padding:54px 32px 36px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px}
.thx-footer h4{color:#fff;font-size:15px;font-weight:600;margin-bottom:16px;letter-spacing:.02em}
.thx-footer-brand .thx-logo-text{margin-bottom:14px}
.thx-footer-brand p{font-size:14px;line-height:1.7;font-weight:300;margin-top:18px}
.thx-trust{display:block;margin-top:18px;max-width:300px;transition:transform .15s,filter .15s}
.thx-trust:hover{transform:translateY(-2px);filter:drop-shadow(0 8px 18px rgba(93,202,165,.25))}
.thx-trust svg{width:100%;height:auto;display:block}
.thx-footer ul{list-style:none}
.thx-footer ul li{margin-bottom:10px}
.thx-footer ul a{font-size:14px;color:rgba(255,255,255,.7);transition:color .15s}
.thx-footer ul a:hover{color:var(--azur-light)}
.thx-footer-contact div{font-size:14px;margin-bottom:10px;display:flex;gap:9px;align-items:flex-start}
.thx-social{display:flex;gap:10px;margin-top:14px}
.thx-social a{width:36px;height:36px;border-radius:9px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:17px;transition:background .15s;color:#fff}
.thx-social a:hover{background:var(--azur)}
.thx-footer-bottom{border-top:1px solid rgba(255,255,255,.12)}
.thx-footer-bottom-inner{max-width:1320px;margin:0 auto;padding:20px 32px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:rgba(255,255,255,.55)}
.thx-footer-bottom a{color:rgba(255,255,255,.7)}

/* ── MOBILE NAV ─────────────────────────────────────────────── */
.thx-mobile-nav{display:none;background:var(--navy-deep);padding:0 32px}
.thx-mobile-nav.open{display:block;padding:14px 32px 22px}
.thx-mobile-nav ul{list-style:none}
.thx-mobile-nav li{border-bottom:1px solid rgba(255,255,255,.08)}
.thx-mobile-nav a{display:block;color:rgba(255,255,255,.9);padding:13px 0;font-size:16px;font-weight:500}
/* Untermenüs im Hamburger: eingerückt, dauerhaft sichtbar (kein Extra-Tap nötig) */
.thx-mobile-nav .sub-menu{padding-left:16px;margin:2px 0 8px;border-left:2px solid rgba(23,137,196,.4)}
.thx-mobile-nav .sub-menu li{border-bottom:none}
.thx-mobile-nav .sub-menu a{padding:9px 0;font-size:15px;font-weight:400;color:rgba(255,255,255,.78)}

/* ── DESKTOP-DROPDOWN (Untermenüs beim Hover) ───────────────── */
/* Top-Level-Punkte: Bezug für das Dropdown; Dropdown dockt an die Segment-Unterkante an */
.thx-nav>ul>li{position:relative;display:flex}
/* Variante B: jeder Oberpunkt als abgesetztes Segment, Text horizontal+vertikal zentriert */
.thx-nav>ul>li>a{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:6px 16px;font-size:13.5px;line-height:1.16;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:10px;transition:background .15s,color .15s,border-color .15s}
/* Grüner CI-Hover (gilt auch fürs aktive Segment) */
.thx-nav>ul>li>a:hover,
.thx-nav .current-menu-item>a:hover,
.thx-nav .current_page_item>a:hover{background:var(--green);color:#fff;border-color:var(--green)}

/* Pfeil-Indikator an Punkten mit Untermenü – zentriert unter dem Label */
.thx-nav .menu-item-has-children>a::after{content:"\25BE";font-size:11px;opacity:.6;margin-top:3px;line-height:1;transition:transform .2s ease,opacity .2s ease}
.thx-nav .menu-item-has-children:hover>a::after,
.thx-nav .menu-item-has-children:focus-within>a::after{transform:rotate(180deg);opacity:1}

/* Das Dropdown-Panel */
.thx-nav .sub-menu{
  position:absolute;top:100%;left:0;
  display:block;min-width:236px;
  background:var(--navy-deep);
  border-radius:12px;
  box-shadow:0 16px 34px rgba(7,33,56,.4);
  padding:8px 0;margin:0;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .18s ease,transform .18s ease,visibility .18s;
  z-index:10001;
}
.thx-nav .menu-item-has-children:hover>.sub-menu,
.thx-nav .menu-item-has-children:focus-within>.sub-menu{
  opacity:1;visibility:visible;transform:translateY(0);
}
/* Letzter Top-Level-Punkt: Dropdown rechtsbündig, damit es nicht aus dem Bild läuft */
.thx-nav>ul>li:last-child .sub-menu{left:auto;right:0}

.thx-nav .sub-menu li{display:block}
.thx-nav .sub-menu a{display:block;padding:10px 22px;font-size:14.5px;font-weight:500;white-space:nowrap;color:rgba(255,255,255,.82)}
.thx-nav .sub-menu a:hover{color:#fff;background:var(--green)}
.thx-nav .sub-menu .current-menu-item>a,.thx-nav .sub-menu .current_page_item>a{box-shadow:none;color:#fff;background:rgba(23,137,196,.22)}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:880px){
  .thx-nav{display:none}
  .thx-burger{display:block}
  .thx-footer-main{grid-template-columns:1fr 1fr;gap:28px}
  .thx-topbar .tb-left{display:none}
  .thx-content-inner{padding:28px 18px}
}
@media(max-width:520px){
  /* Footer bleibt ZWEISPALTIG (nicht einspaltig) — kürzer/kompakter */
  .thx-footer-main{grid-template-columns:1fr 1fr;gap:24px 20px;padding:38px 22px 28px}
  .thx-footer-brand{grid-column:1 / -1}
  .thx-header-inner{padding:0 18px}
  .thx-topbar-inner{padding:7px 18px}
  .thx-mobile-nav.open{padding:14px 18px 22px}
  .thx-footer-bottom-inner{padding:18px 22px}
}

/* WordPress-Pflicht-Klassen */
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}
.aligncenter{margin-left:auto;margin-right:auto;display:block}
.alignleft{float:left;margin-right:1.5em}
.alignright{float:right;margin-left:1.5em}

/* ════════════════════════════════════════════════════════════════
   v1.0.5+ — Kontakt-Button + Modal + Mobil-Layout
   ════════════════════════════════════════════════════════════════ */

/* ── KONTAKT-BUTTON IM FOOTER ──────────────────────────────── */
.thx-contact-btn{display:inline-flex;align-items:center;gap:8px;background:var(--green);color:#fff;font-family:inherit;font-size:14px;font-weight:600;border:none;padding:11px 20px;border-radius:11px;cursor:pointer;margin-top:14px;box-shadow:0 6px 18px -8px rgba(47,170,94,.55);transition:transform .15s,background .15s,box-shadow .15s}
.thx-contact-btn:hover{transform:translateY(-2px);background:#28994f;box-shadow:0 12px 24px -8px rgba(47,170,94,.7)}
.thx-contact-btn:focus-visible{outline:2px solid #fff;outline-offset:3px}

/* Footer-Contact-Row: Desktop = untereinander, Mobil = nebeneinander */
.thx-contact-row{display:flex;flex-direction:column;align-items:flex-start;gap:0}
.thx-contact-row .thx-trust{margin-top:18px}
@media(max-width:520px){
  /* Kontakt-Block bekommt mobil die volle Footer-Breite */
  .thx-footer-contact{grid-column:1 / -1}
  .thx-contact-row{flex-direction:row;align-items:center;gap:14px;flex-wrap:nowrap;margin-top:6px}
  .thx-contact-row .thx-contact-btn{margin-top:0;flex-shrink:0}
  .thx-contact-row .thx-trust{margin-top:0;flex:1 1 auto;min-width:0;max-width:300px}
  .thx-contact-row .thx-trust svg{width:100%;height:auto}
}

/* ── KONTAKT-MODAL ─────────────────────────────────────────── */
.thx-contact-modal{display:none;position:fixed;inset:0;z-index:99999;background:rgba(7,33,56,.86);backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:24px}
.thx-contact-modal.open{display:flex}
.thx-contact-modal-box{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 100%);border:1px solid rgba(95,194,232,.28);border-radius:20px;padding:42px 36px 34px;max-width:440px;width:100%;position:relative;text-align:center;color:#fff;box-shadow:0 40px 90px -28px rgba(0,0,0,.7)}
.thx-contact-modal-close{position:absolute;top:14px;right:16px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;width:34px;height:34px;border-radius:50%;font-size:18px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;font-family:inherit;transition:background .15s}
.thx-contact-modal-close:hover{background:rgba(255,255,255,.2)}
.thx-contact-modal-ico{display:flex;justify-content:center;color:var(--azur-light);margin-bottom:12px}
.thx-contact-modal-ico svg{display:block;filter:drop-shadow(0 4px 12px rgba(23,137,196,.4))}
.thx-contact-modal h3{font-family:'Fraunces',Georgia,serif;font-size:24px;font-weight:600;color:#fff;margin-bottom:6px;line-height:1.2}
.thx-contact-modal-sub{font-size:15px;color:var(--azur-light);font-weight:500;margin-bottom:26px;font-style:italic;font-family:'Fraunces',Georgia,serif}
.thx-contact-modal-items{display:flex;flex-direction:column;gap:12px;margin-bottom:22px}
.thx-contact-modal-item{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:13px;padding:14px 18px;text-align:left;color:#fff;text-decoration:none;transition:background .15s,border-color .15s,transform .15s}
.thx-contact-modal-item:hover{background:rgba(255,255,255,.13);border-color:rgba(95,194,232,.4);transform:translateY(-2px)}
.thx-contact-modal-ic{width:42px;height:42px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;background:rgba(23,137,196,.18);border:1px solid rgba(95,194,232,.32);border-radius:11px;color:var(--azur-light)}
.thx-contact-modal-ic svg{display:block}
.thx-contact-modal-text{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.thx-contact-modal-lbl{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:600}
.thx-contact-modal-val{font-size:15.5px;font-weight:500;color:#fff;word-break:break-word}
.thx-contact-modal-foot{font-size:13px;color:rgba(255,255,255,.55);line-height:1.55;margin:0}
body.thx-modal-locked{overflow:hidden}
@media(max-width:520px){
  .thx-contact-modal-box{padding:36px 24px 28px}
  .thx-contact-modal h3{font-size:21px}
}
