/*
Theme Name: Tivoli Werkstatt Pro
Theme URI: https://tivoli-admin.ch
Author: Michael / Fridolin
Description: Flexibles Tivoli Theme mit stabilen Backend-Einstellungen, Mobile-Menü-Optimierung und sauberem App-/Werkstatt-Layout.
Version: 2.1.0
Text Domain: tivoli-werkstatt-pro
*/

:root{
  --tw-bg:#f5f7fa;
  --tw-card:#ffffff;
  --tw-border:#e2e8f0;
  --tw-text:#111827;
  --tw-text-muted:#6b7280;
  --tw-accent:#ef4444;
  --tw-accent-dark:#b91c1c;
  --tw-header-bg:#020617;
  --tw-header-text:#e5e7eb;
  --tw-dropdown-bg:#0b1120;
  --tw-footer-bg:#020617;
  --tw-footer-text:#9ca3af;
  --tw-menu-hover-bg:rgba(255,255,255,.06);
  --tw-radius:10px;
  --tw-page-max:1120px;
  --tw-pad-desktop:0px;
  --tw-pad-mobile:20px;
  --tw-mobile-breakpoint:768px;
  --tw-grid-3-breakpoint:1024px;
  --tw-logo-desktop:260px;
  --tw-logo-mobile:26px;
  --tw-mobile-menu-width:92vw;
  --tw-body-bg-image:none;
  --font-size-base:clamp(15px,1.5vw,17px);
  --font-size-h1:clamp(22px,3vw,28px);
  --font-size-h2:clamp(19px,2.5vw,24px);
  --font-size-h3:clamp(17px,2vw,20px);
  --tw-shadow:0 14px 34px rgba(15,23,42,.08);
}
*,:before,:after{box-sizing:border-box}
html,body{margin:0;padding:0}
body.menu-open{overflow:hidden}
body{
  background:var(--tw-bg);
  background-image:var(--tw-body-bg-image);
  background-size:cover;
  background-position:center;
  color:var(--tw-text);
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:var(--font-size-base);
  line-height:1.6;
}
a{color:var(--tw-accent);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
.site{min-height:100vh;display:flex;flex-direction:column}
.site-main{flex:1 0 auto}
.site-footer{flex-shrink:0}
.tivoli-container{width:min(100%,var(--tw-page-max));margin:0 auto;padding:1.5rem var(--tw-pad-mobile)}
@media (min-width:769px){.tivoli-container{padding:2rem var(--tw-pad-desktop)}}
body.tw-layout-boxed .site-main{padding:1rem}
body.tw-layout-boxed .tivoli-container{background:rgba(255,255,255,.04);border:1px solid rgba(0,0,0,.03);border-radius:calc(var(--tw-radius) + 10px);box-shadow:var(--tw-shadow)}

.site-header{
  background:var(--tw-header-bg);
  color:var(--tw-header-text);
  border-bottom:1px solid rgba(148,163,184,.25);
  z-index:100;
}
.site-header-inner{
  width:min(100%,var(--tw-page-max));
  margin:0 auto;
  padding:.75rem max(var(--tw-pad-mobile),16px);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
@media (min-width:769px){.site-header-inner{padding:.75rem max(var(--tw-pad-desktop),16px)}}
.site-branding{display:flex;align-items:center;gap:.85rem;min-width:0;flex:1}
.site-logo,.custom-logo{width:auto;max-width:var(--tw-logo-desktop);height:auto;max-height:72px;border-radius:10px;object-fit:contain}
.site-title,.site-title a{margin:0;color:inherit;font-weight:700;font-size:1.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none}
.site-tagline{margin:0;font-size:.84rem;opacity:.85}

.menu-toggle{
  appearance:none;border:1px solid rgba(255,255,255,.22);background:transparent;color:var(--tw-header-text);
  border-radius:999px;padding:.5rem .8rem;font-size:.92rem;display:none;align-items:center;gap:.55rem;cursor:pointer
}
.menu-toggle:hover{background:rgba(255,255,255,.06)}
.menu-toggle-icon{width:18px;height:2px;background:currentColor;border-radius:999px;box-shadow:0 5px 0 currentColor,0 -5px 0 currentColor;display:block}

.main-navigation > ul,
.main-navigation > div > ul{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:1.15rem}
.main-navigation li{position:relative;list-style:none}
.main-navigation a{display:inline-flex;align-items:center;color:var(--tw-header-text);padding:.4rem 0;border-bottom:2px solid transparent;font-size:.95rem;text-decoration:none}
.main-navigation .current-menu-item>a,
.main-navigation .current-page-ancestor>a,
.main-navigation a:hover{border-bottom-color:var(--tw-accent)}

body.tw-menu-pill .main-navigation a{padding:.5rem .8rem;border-radius:999px;border-bottom:none}
body.tw-menu-pill .main-navigation a:hover,
body.tw-menu-pill .main-navigation .current-menu-item>a,
body.tw-menu-pill .main-navigation .current-page-ancestor>a{background:var(--tw-menu-hover-bg)}
body.tw-menu-minimal .main-navigation a{padding:.2rem 0;border-bottom:none;opacity:.92}
body.tw-menu-minimal .main-navigation a:hover,
body.tw-menu-minimal .main-navigation .current-menu-item>a,
body.tw-menu-minimal .main-navigation .current-page-ancestor>a{opacity:1;color:#fff}

.main-navigation ul.sub-menu{
  display:none;position:absolute;top:100%;left:0;min-width:230px;margin:0;padding:.45rem 0;
  background:var(--tw-dropdown-bg);border:1px solid rgba(148,163,184,.28);border-radius:14px;
  box-shadow:0 18px 45px rgba(0,0,0,.35);z-index:9999
}
.main-navigation li:hover>ul.sub-menu,
.main-navigation li:focus-within>ul.sub-menu{display:block}
.main-navigation ul.sub-menu li{display:block}
.main-navigation ul.sub-menu a{display:block;padding:.7rem .95rem;border-bottom:none;white-space:nowrap}
.main-navigation ul.sub-menu a:hover{background:var(--tw-menu-hover-bg)}
.main-navigation .menu-item-has-children>a::after{content:"▾";font-size:.72rem;margin-left:.35rem;opacity:.82}
.mobile-submenu-toggle{display:none}
.site-mobile-backdrop{display:none}

.tw-page-header{padding:1rem 0 .9rem}
.tw-page-header h1{margin:0 0 .35rem;font-size:var(--font-size-h1);line-height:1.2}
.tw-page-header p{margin:0;color:var(--tw-text-muted);max-width:55rem}
.tw-page-header-compact{padding-top:.4rem}
.tw-muted{color:var(--tw-text-muted)}

.tw-card{background:var(--tw-card);border:1px solid var(--tw-border);border-radius:var(--tw-radius);padding:1.25rem;box-shadow:var(--tw-shadow);margin-bottom:1.25rem;overflow:auto}
.tw-card-no-padding{padding:0}
.tw-card h2{margin-top:0;font-size:var(--font-size-h2)}
.tw-card h3{font-size:var(--font-size-h3)}
.tw-grid-2,.tw-grid-3{display:grid;grid-template-columns:1fr;gap:1rem}
@media (min-width:900px){.tw-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (min-width:1024px){.tw-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}}

.tw-btn,.button,.wp-element-button{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.6rem 1rem;
  border-radius:12px;border:1px solid transparent;background:var(--tw-accent);color:#fff!important;text-decoration:none!important;cursor:pointer
}
.tw-btn:hover,.button:hover,.wp-element-button:hover{filter:brightness(.98)}
.tw-btn-secondary{background:#fff;color:var(--tw-text)!important;border-color:var(--tw-border)}
.tw-form-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width:900px){.tw-form-grid.tw-form-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.tw-form-grid.tw-form-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
input[type=text],input[type=email],input[type=number],input[type=date],input[type=password],select,textarea{
  width:100%;max-width:100%;padding:.72rem .82rem;border:1px solid var(--tw-border);border-radius:12px;background:#fff;color:var(--tw-text)
}
textarea{min-height:120px;resize:vertical}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--tw-accent);box-shadow:0 0 0 4px rgba(239,68,68,.08)}

.tw-app-shell{min-height:360px}.tw-app-shell-dark{background:#08111f;color:#e5ecf7}
.tw-app-header{padding:1rem 1.2rem;border-bottom:1px solid rgba(255,255,255,.08)}
.tw-app-header-title{font-size:1.05rem;font-weight:700}.tw-app-header-subtitle{font-size:.88rem;opacity:.75}
.tw-app-main{padding:1rem}

.site-footer{background:var(--tw-footer-bg);color:var(--tw-footer-text);margin-top:2rem}
.site-footer-inner{width:min(100%,var(--tw-page-max));margin:0 auto;padding:1rem max(var(--tw-pad-mobile),16px);display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem}
@media (min-width:769px){.site-footer-inner{padding:1rem max(var(--tw-pad-desktop),16px)}}
.site-footer a{color:inherit}
.footer-menu{list-style:none;display:flex;flex-wrap:wrap;gap:.8rem;margin:0;padding:0}
.footer-menu li{list-style:none}

/* Mobile Layout */
@media (max-width:768px){
  .menu-toggle{display:inline-flex}
  .site-title{font-size:1rem}
  body.tw-mobile-compact .site-tagline{display:none}
  body.tw-mobile-compact .site-header-inner{padding:.48rem max(var(--tw-pad-mobile),12px)}
  body.tw-mobile-compact .site-logo,
  body.tw-mobile-compact .custom-logo{max-width:var(--tw-logo-mobile);max-height:var(--tw-logo-mobile)}

  .main-navigation{
    display:none;position:fixed;top:0;right:0;bottom:0;width:var(--tw-mobile-menu-width);max-width:430px;z-index:9999;
    background:var(--tw-dropdown-bg);padding:1rem 1rem 1.4rem;overflow:auto;box-shadow:-12px 0 30px rgba(0,0,0,.26)
  }
  body.tw-mobile-menu-fullscreen .main-navigation{left:0;width:100%;max-width:none}
  body.tw-mobile-menu-dropdown .main-navigation{
    position:absolute;top:100%;left:max(var(--tw-pad-mobile),12px);right:max(var(--tw-pad-mobile),12px);bottom:auto;width:auto;max-width:none;
    border-radius:16px;box-shadow:0 14px 30px rgba(0,0,0,.3)
  }
  .main-navigation.toggled{display:block!important}
  .site-mobile-backdrop.is-visible{display:block;position:fixed;inset:0;background:rgba(2,6,23,.45);z-index:9998}
  body.tw-mobile-menu-dropdown .site-mobile-backdrop.is-visible{display:none}

  .main-navigation > ul,
  .main-navigation > div > ul{display:block;margin:0;padding:3.2rem 0 0;list-style:none}
  .main-navigation li{display:block}
  .main-navigation a{display:flex;align-items:center;justify-content:space-between;padding:.9rem .15rem;border:0;white-space:normal}
  .main-navigation .menu-item-has-children>a::after{display:none}
  .mobile-submenu-toggle{
    display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;margin-left:.5rem;border:1px solid rgba(255,255,255,.16);
    background:rgba(255,255,255,.05);color:#fff;border-radius:10px;cursor:pointer;flex:0 0 34px
  }
  .mobile-submenu-toggle:before{content:"+";font-size:1.1rem;line-height:1}
  .menu-item-mobile-open > .mobile-submenu-toggle:before{content:"−"}

  .main-navigation ul.sub-menu{display:none;position:static;min-width:0;padding:0 0 .25rem .8rem;margin:0;background:transparent;border:0;box-shadow:none;border-left:2px solid rgba(255,255,255,.12);border-radius:0}
  body.tw-mobile-submenu-inline .main-navigation ul.sub-menu{display:block!important}
  .menu-item-mobile-open > ul.sub-menu{display:block}
  .main-navigation ul.sub-menu a{padding:.72rem .2rem;border:0}

  .tw-grid-2,.tw-grid-3{grid-template-columns:1fr}
  .site-footer-inner{flex-direction:column;align-items:flex-start}
}

/* Mobile theme variants */
@media (max-width:768px){
  body.tw-mobile-theme-app{background:#06111f;color:#eef3fb}
  body.tw-mobile-theme-app .tivoli-container{padding-top:1rem}
  body.tw-mobile-theme-app .tw-card{background:#0d1728;border-color:rgba(255,255,255,.08);color:#eef3fb;box-shadow:none}
  body.tw-mobile-theme-app .tw-card h2,
  body.tw-mobile-theme-app .tw-card h3,
  body.tw-mobile-theme-app .tw-page-header h1{color:#fff}
  body.tw-mobile-theme-app .tw-muted,
  body.tw-mobile-theme-app .tw-page-header p{color:#9fb0c9}
  body.tw-mobile-theme-app input,
  body.tw-mobile-theme-app select,
  body.tw-mobile-theme-app textarea{background:#101d32;color:#eef3fb;border-color:rgba(255,255,255,.1)}
}

/* WordPress content basics */
.alignwide{max-width:1200px}.alignfull{max-width:none;width:100vw;margin-left:50%;transform:translateX(-50%)}
.wp-block-table table{border-collapse:collapse;width:100%}
.wp-block-table th,.wp-block-table td{border:1px solid var(--tw-border);padding:.75rem}

/* Plugin bridge */
.tv-ui .tv-card,
.ta-card{border-radius:var(--tw-radius)}
