/* dr-loher-staerkle.ch — Tailwind v2 custom theme
   Swiss GP practice — calm medical blue on white.
   Spec tokens: #004F99 #3E6FAB #B6DEF2 #EAF3FB #333333 #666666 #FFFFFF
   (Tailwind v2 = no JIT arbitrary values; theme colors are plain CSS here.)
*/
:root {
  --blue: #004F99;
  --blue-mid: #3E6FAB;
  --blue-light: #B6DEF2;
  --skytint: #EAF3FB;
  --ink: #333333;
  --slate: #666666;
  --white: #FFFFFF;
  --line: #DCE7F0;
  /* shared scaffold class aliases (le-baryton used dark names) */
  --stage: #FFFFFF;
  --charcoal: #EAF3FB;
  --amber: #004F99;      /* "accent" -> medical blue */
  --amber-bright: #3E6FAB;
  --muted: #666666;
  --hairline: #DCE7F0;
}
body {
  background: var(--white);
  color: var(--ink);
  font-family: "Open Sans", Arial, sans-serif;
  font-size: 16px;
  line-height: 1.65;
  margin: 0;
  display: flex; flex-direction: column; min-height: 100vh;
}
main { flex: 1 0 auto; }
h1,h2,h3,h4 { font-family: "Lato", "Helvetica Neue", Arial, sans-serif; color: var(--blue); font-weight: 700; line-height: 1.2; }
h1 { font-size: 36px; } h2 { font-size: 25px; } h3 { font-size: 19px; }
a { color: var(--blue); text-decoration: none; }
a:hover { color: var(--blue-mid); }

.bg-stage { background: var(--white); }
.bg-charcoal { background: var(--skytint); }
.text-amber { color: var(--blue) !important; }
.bg-amber { background: var(--blue) !important; }
.border-hairline { border-color: var(--hairline) !important; }
.text-muted { color: var(--slate) !important; }
.font-display { font-family: "Lato", Arial, sans-serif; }
.container-x { max-width: 1140px; margin: 0 auto; padding: 0 24px; }

/* Header */
.site-header { background: var(--white); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 50; }
.site-header .brand { font-family: "Lato", serif; font-size: 22px; color: var(--blue); font-weight: 700; }
.site-nav a { color: var(--ink); font-weight: 600; padding: 8px 12px; display: inline-block; }
.site-nav a:hover { color: var(--blue-mid); }
.nav-burger { color: var(--blue); cursor: pointer; }

/* Hero */
.hero { position: relative; background: var(--skytint); overflow: hidden; }
.hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .45; }
.hero__inner { position: relative; z-index: 2; padding: 88px 24px; max-width: 880px; margin: 0 auto; text-align: center; }
.hero h1 { font-size: 44px; color: var(--blue); margin-bottom: 16px; }
.hero p { color: var(--ink); font-size: 19px; }
@media (max-width: 640px){ .hero h1 { font-size: 30px; } }

/* Buttons */
.btn-amber { background: var(--blue); color: var(--white); padding: 12px 28px; border-radius: 4px; display:inline-block; font-weight:600; }
.btn-amber:hover { background: var(--blue-mid); color: var(--white); }
.btn-ghost { border: 1px solid var(--blue); color: var(--blue); padding: 11px 26px; border-radius: 4px; display:inline-block; }
.btn-ghost:hover { background: var(--blue); color: var(--white); }

/* Sections */
.section { padding: 60px 0; }
.section-head { margin-bottom: 36px; text-align: center; }
.section-head .kicker { color: var(--blue-mid); text-transform: uppercase; letter-spacing: .14em; font-size: 13px; font-weight: 700; }

/* Cards */
.card { background: var(--white); border: 1px solid var(--line); border-radius: 8px; overflow: hidden; height: 100%; box-shadow: 0 3px 14px rgba(0,79,153,.06); }
.card img { width: 100%; height: 200px; object-fit: cover; display:block; }
.card .card-body { padding: 20px; }
.card h3 { font-size: 19px; margin: 0 0 8px; }
.card h3 a { color: var(--blue); }
.card h3 a:hover { color: var(--blue-mid); }
.card .meta { color: var(--blue-mid); font-size: 13px; font-weight: 700; }

/* Prose */
.site-prose { color: var(--ink); }
.site-prose h1,.site-prose h2,.site-prose h3 { color: var(--blue); }
.site-prose a { color: var(--blue); text-decoration: underline; text-decoration-color: rgba(0,79,153,.4); }
.site-prose a:hover { color: var(--blue-mid); }
.site-prose img { max-width: 100%; height: auto; border-radius: 6px; margin: 12px 0; }
.site-prose table { width: 100%; border-collapse: collapse; margin: 16px 0; }
.site-prose th,.site-prose td { border: 1px solid var(--line); padding: 8px 10px; text-align: left; }
.site-prose th { background: var(--blue); color: var(--white); }
.site-prose blockquote { border-left: 4px solid var(--blue-light); padding: 6px 16px; background: var(--skytint); margin: 16px 0; }
.page-title { color: var(--blue); margin: 28px 0 18px; }

/* media grid */
.media-grid { display:grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap:14px; }
.media-grid img { width:100%; height:220px; object-fit:cover; border-radius:6px; }

/* CTA */
.cta { background: var(--blue); color: var(--white); padding: 56px 0; text-align: center; }
.cta h2 { color: var(--white); }

/* breadcrumb */
.breadcrumb-bar { background: var(--skytint); padding: 10px 0; border-bottom: 1px solid var(--line); }
.breadcrumb-bar a { color: var(--blue); }
.breadcrumb-bar span { color: var(--slate); }

/* Footer */
.site-footer { background: var(--blue); color: rgba(255,255,255,.85); padding: 48px 0 24px; }
.site-footer h4 { color: var(--white); font-size: 16px; font-family: "Lato", sans-serif; }
.site-footer a, .site-footer ul a { color: rgba(255,255,255,.82); }
.site-footer a:hover { color: var(--white); }
.site-footer ul { list-style: none; margin: 0; padding: 0; }
.site-footer li { margin-bottom: 6px; }
.site-footer__bottom { border-top: 1px solid rgba(255,255,255,.18); margin-top: 28px; padding-top: 16px; text-align: center; color: rgba(255,255,255,.6); font-size: 13px; }
.separator { border: 0; border-top: 1px solid var(--line); margin: 18px 0; }

/* CSS-only mobile nav */
#navtoggle { display: none; }
@media (max-width: 767px){
  .site-nav { display: none; width: 100%; }
  #navtoggle:checked ~ .site-nav { display: block; }
  .site-nav a { display: block; border-top: 1px solid var(--line); }
}
@media (min-width: 768px){ .nav-burger { display: none; } }
