/* tabellio.ch — globale Navigation + Fat-Footer (eine Quelle für alle Seiten)
   Subseiten nutzen .site-head komplett; index.html nutzt nur .sh-drop/.sh-menu
   innerhalb des bestehenden Headers (Sprachwähler bleibt dort erhalten). */

/* ===== Premium-Fundament ===== */
:root{
  --ease:cubic-bezier(.2,.7,.2,1);
  --dur-1:120ms; --dur-2:240ms; --dur-3:420ms;
}

/* Tabellenziffern: Beträge stehen wie gemeisselt (Quittung, Tabellen, Totale) */
body{font-variant-numeric:lining-nums tabular-nums}

/* Einheitlicher, sichtbarer Fokus */
:focus-visible{outline:2px solid var(--red,#C22E1F);outline-offset:2px}

/* Anker landen UNTER dem Sticky-Header, nicht darunter versteckt */
section[id],[id^="rechner"],[id^="anlaesse"],[id^="tools"],[id^="kantone"],[id^="wissen"],[id^="services"],[id^="notare"],[id^="fuer-notare"],[id^="faq"]{scroll-margin-top:86px}
html{scrollbar-gutter:stable}

/* EIN Interaktions-Vokabular für alles Klickbare */
a,button,input,select,textarea,summary{
  transition:color var(--dur-1) var(--ease),background-color var(--dur-1) var(--ease),
    border-color var(--dur-1) var(--ease),box-shadow var(--dur-2) var(--ease),
    transform var(--dur-2) var(--ease),opacity var(--dur-2) var(--ease);
}

/* Scroll-Reveal für alle Seiten (reveal.js setzt .in; index hat eigenes System) */
.rv2{opacity:0;transform:translateY(14px);transition:opacity var(--dur-3) var(--ease),transform var(--dur-3) var(--ease)}
.rv2.in{opacity:1;transform:none}
.rvg>*{opacity:0;transform:translateY(14px);transition:opacity var(--dur-3) var(--ease),transform var(--dur-3) var(--ease)}
.rvg.in>*{opacity:1;transform:none}
.rvg.in>*:nth-child(2){transition-delay:60ms}
.rvg.in>*:nth-child(3){transition-delay:120ms}
.rvg.in>*:nth-child(4){transition-delay:180ms}
.rvg.in>*:nth-child(5){transition-delay:240ms}
.rvg.in>*:nth-child(6){transition-delay:300ms}
.rvg.in>*:nth-child(n+7){transition-delay:360ms}
@media(prefers-reduced-motion:reduce){
  .rv2,.rvg>*{opacity:1 !important;transform:none !important;transition:none !important}
}

/* Custom Selects: eigener Chevron im Brand-Strich statt Browser-Standard */
select{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1.5l5 5 5-5' fill='none' stroke='%231B1712' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
  background-repeat:no-repeat !important;background-position:right 13px center !important;background-size:12px 8px !important;
  padding-right:36px !important;
}
select::-ms-expand{display:none}

/* Sanfter Seitenwechsel (View Transitions, progressive enhancement) */
@view-transition{navigation:auto}
@media(prefers-reduced-motion:reduce){@view-transition{navigation:none}}

/* Lange deutsche Komposita sauber umbrechen (lang="de-CH" liefert die Trennregeln) */
h1,h2,h3,h4,h5{hyphens:auto;overflow-wrap:break-word}

/* Breite Tabellen scrollen mobil in sich selbst statt die Seite zu sprengen */
main.art table{display:block;overflow-x:auto;max-width:100%}

/* Headings als Block: verhindert Min-Content-Ueberlauf des anonymen Flex-Items
   (artikel.css setzt display:flex) bei langen deutschen Komposita */
main.art h1,main.art h2,main.art h3{display:block}

/* ===== Dropdown-Mechanik (Header-unabhängig) ===== */
.sh-drop{position:relative;display:flex;align-items:stretch}
.sh-drop>a{display:flex;align-items:center;gap:5px}
.sh-drop .car{font-size:9px;opacity:.55;transform:translateY(1px)}
.sh-menu{
  display:none;position:absolute;top:100%;left:-10px;min-width:250px;z-index:240;
  background:var(--card,#FCFAF4);border:2px solid var(--ink,#1B1712);border-radius:3px;
  box-shadow:5px 6px 0 rgba(27,23,18,.14);padding:8px;
}
.sh-drop:hover>.sh-menu,.sh-drop:focus-within>.sh-menu{display:block}
.sh-menu a{
  display:flex !important;align-items:center;gap:9px;padding:10px 12px !important;
  font-size:13.5px;font-weight:600;color:var(--ink,#1B1712) !important;text-decoration:none;
  border-radius:2px;border-bottom:1px dotted var(--line,rgba(27,23,18,.18));letter-spacing:0;
  text-transform:none;height:auto !important;
}
.sh-menu a:last-child{border-bottom:none}
.sh-menu a:hover{background:var(--paper-deep,#ECE5D8)}
.sh-menu a .ico{width:20px;text-align:center;flex:none;font-size:15px}
.sh-menu a b{color:var(--red,#C22E1F)}
.sh-menu .sh-sep{border-top:1px dashed var(--line-strong,rgba(27,23,18,.35));margin:6px 4px}

/* ===== Globaler Header (Subseiten) ===== */
.site-head{
  position:sticky;top:0;z-index:230;background:var(--paper,#F4EFE5);
  border-bottom:1px solid var(--line-strong,rgba(27,23,18,.35));
}
.site-head .sh-in{
  max-width:1160px;margin:0 auto;padding:0 20px;display:flex;align-items:center;gap:20px;
}
.site-head .logo{display:flex;align-items:center;gap:10px;padding:13px 0;text-decoration:none;color:var(--ink,#1B1712);margin-right:auto}
.site-head .logo-mark{width:30px;height:30px;flex:none}
.site-head .logo-word{font-weight:900;font-size:19px;letter-spacing:-.02em}
.site-head .logo-word em{font-style:normal;color:var(--red,#C22E1F)}
.site-head nav{display:flex;align-items:stretch;gap:2px}
.site-head nav>a,.site-head nav .sh-drop>a{
  display:flex;align-items:center;padding:0 13px;text-decoration:none;
  color:var(--ink-soft,#4A443B);font-size:13.5px;font-weight:700;white-space:nowrap;
}
.site-head nav>a:hover,.site-head nav .sh-drop>a:hover{color:var(--red,#C22E1F)}
.site-head nav a.on{color:var(--red,#C22E1F)}
.site-head .sh-cta{
  align-self:center;background:var(--ink,#1B1712);color:var(--paper,#F4EFE5) !important;
  padding:9px 14px !important;border-radius:2px;font-family:'Spline Sans Mono',monospace;
  font-size:10.5px !important;letter-spacing:.08em;text-transform:uppercase;margin-left:8px;
}
.site-head .sh-cta:hover{background:var(--red,#C22E1F);color:var(--paper,#F4EFE5) !important}
.site-head .sh-burger{
  display:none;background:none;border:none;font-size:23px;line-height:1;cursor:pointer;
  color:var(--ink,#1B1712);padding:6px 4px;
}
@media(max-width:940px){
  .site-head .sh-burger{display:block}
  .site-head nav{
    display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    background:var(--paper,#F4EFE5);border-bottom:2px solid var(--ink,#1B1712);padding:8px 14px 16px;
    box-shadow:0 12px 24px rgba(27,23,18,.12);
  }
  .site-head.open nav{display:flex}
  .site-head nav>a,.site-head nav .sh-drop>a{padding:12px 6px;border-bottom:1px dotted var(--line,rgba(27,23,18,.18))}
  .sh-drop{flex-direction:column;align-items:stretch}
  .sh-menu{position:static;display:block;border:none;box-shadow:none;padding:0 0 4px 14px;min-width:0;background:transparent}
  .sh-menu a{padding:9px 6px !important}
  .site-head .sh-cta{margin:12px 6px 0;justify-content:center;display:flex}
}

/* Index-Header (eigener Burger via header.nav-open): Dropdowns mobil inline aufklappen */
@media(max-width:940px){
  header:not(.site-head) nav .sh-drop{flex-direction:column;align-items:stretch}
  header:not(.site-head) nav .sh-menu{
    position:static;display:block;border:none;box-shadow:none;background:transparent;
    padding:0 0 6px 16px;min-width:0;
  }
  header:not(.site-head) nav .sh-drop>a .car{display:none}
}

/* ===== Fat-Footer (alle Seiten) ===== */
.site-foot{background:var(--card,#FCFAF4);border-top:2px solid var(--ink,#1B1712);margin-top:70px}
.site-foot .sf-in{max-width:1160px;margin:0 auto;padding:44px 20px 26px}
.site-foot .sf-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:28px}
@media(max-width:860px){.site-foot .sf-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:460px){.site-foot .sf-grid{grid-template-columns:minmax(0,1fr)}}
.site-foot h5{
  font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--red,#C22E1F);margin:0 0 12px;
}
.site-foot .sf-grid a{
  display:block;padding:5px 0;font-size:13.5px;color:var(--ink-soft,#4A443B);
  text-decoration:none;line-height:1.5;
}
.site-foot .sf-grid a:hover{color:var(--red,#C22E1F)}
.site-foot .sf-brand{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  border-top:1px dashed var(--line-strong,rgba(27,23,18,.35));margin-top:34px;padding-top:20px;
}
.site-foot .sf-brand svg{width:30px;height:30px;flex:none}
.site-foot .sf-brand span{
  font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-soft,#4A443B);
}
.site-foot .sf-legal{
  font-family:'Spline Sans Mono',monospace;font-size:9.5px;letter-spacing:.05em;line-height:1.9;
  color:var(--ink-soft,#4A443B);margin-top:14px;text-transform:uppercase;
}
