/* File: assets/css/layout.css */
/* Header (split: topbar + main) / Footer / containers — light theme, square 4px. */

:where(.dag-container,.container,.site-container,.wrap){
  width:100%;
  max-width:var(--dag-container);
  margin-inline:auto;
  padding-inline:var(--dag-gutter);
}

.site-main{min-height:60vh}

/* ═══════════ TOP BAR ═══════════ */
.site-topbar{
  background:var(--dag-topbar-bg);
  color:var(--dag-topbar-fg);
  font-size:12.5px;
  letter-spacing:.02em;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.site-topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  min-height:var(--dag-topbar-h);
  padding-block:6px;
  flex-wrap:wrap;
}

.site-topbar__left,
.site-topbar__right{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}

.site-topbar__item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  color:var(--dag-topbar-fg);
  font-weight:500;
  white-space:nowrap;
  transition:color var(--anim-fast) ease;
}

a.site-topbar__item:hover{
  color:var(--dag-accent);
}

.site-topbar__item--hours{ color:var(--dag-topbar-muted); cursor:default }
.site-topbar__ico{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--dag-accent);
  flex:0 0 auto;
}

.site-topbar__item--phone{
  font-weight:700;
}

@media (max-width: 820px){
  .site-topbar{font-size:12px}
  .site-topbar__inner{justify-content:center; gap:12px}
  .site-topbar__item--addr .site-topbar__txt{
    max-width:60vw;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .site-topbar__item--hours{display:none}
}

@media (max-width: 520px){
  .site-topbar__item--email{display:none}
  .site-topbar__item--addr .site-topbar__txt{max-width:50vw}
}

/* ═══════════ MAIN HEADER ═══════════ */
.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:var(--dag-surface);
  border-bottom:1px solid var(--dag-border);
  box-shadow:var(--dag-shadow-xs);
}

.site-header__inner{
  position:relative;
  display:flex;
  align-items:center;
  gap:18px;
  min-height:var(--dag-header-h);
  padding-block:10px;
}

/* Branding */
.site-branding{flex:0 0 auto; min-width:0}
.site-branding__home{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:var(--dag-secondary);
  min-width:0;
}

.site-branding__logo{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 8px;
  border-radius:var(--dag-radius-sm);
  background:var(--dag-surface);
  border:1px solid var(--dag-border);
  flex:0 0 auto;
}

.site-branding__logo-img{
  display:block;
  max-height:clamp(40px, 3vw, 56px);
  max-width:clamp(140px, 14vw, 240px);
  object-fit:contain;
}

.site-branding__logo-fallback{
  width:32px;height:32px;border-radius:var(--dag-radius-sm);
  background:var(--dag-primary);
  box-shadow:var(--dag-shadow-xs);
}

.site-branding__name{
  font-family:var(--dag-font-display);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.04em;
  font-size:clamp(18px, 14px + .8vw, 24px);
  line-height:1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:min(38vw, 420px);
  color:var(--dag-secondary);
}

/* Desktop nav */
.site-header__nav{
  flex:1 1 auto;
  min-width:0;
  display:flex;
  justify-content:center;
  align-items:center;
}

.site-header__menu{
  display:flex;
  flex-wrap:wrap;
  gap:2px;
  align-items:center;
}

.site-header__menu a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:8px 16px;
  border-radius:var(--dag-radius-sm);
  text-decoration:none;
  color:var(--dag-text);
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:12.5px;
  border:1px solid transparent;
  background:transparent;
  white-space:nowrap;
  transition:background var(--anim-fast) ease, color var(--anim-fast) ease, border-color var(--anim-fast) ease;
  position:relative;
}

.site-header__menu a::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:4px;
  height:2px;
  width:0;
  background:var(--dag-primary);
  transform:translateX(-50%);
  transition:width var(--anim-fast) ease;
}

.site-header__menu a:hover{
  color:var(--dag-primary);
}
.site-header__menu a:hover::after{ width:60%; }

.site-header__menu .is-current > a,
.site-header__menu a[aria-current="page"]{
  color:var(--dag-primary);
}
.site-header__menu .is-current > a::after,
.site-header__menu a[aria-current="page"]::after{ width:60%; }

/* Right actions */
.site-header__actions{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  gap:10px;
}

.site-header__cta{
  min-height:42px;
  padding-inline:18px;
  border-radius:var(--dag-radius-sm);
  white-space:nowrap;
  font-size:13px;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.site-header__cta-ico{flex:0 0 auto}

.site-burger{display:inline-flex}

@media (max-width: 980px){
  .site-header__inner{min-height:60px;padding-block:8px;gap:12px}
  .site-header__nav{display:none}
  .site-branding__name{max-width:52vw}
}

@media (min-width: 981px){.site-burger{display:none}}

@media (max-width: 520px){
  .site-branding__logo{padding:4px 6px}
  .site-branding__logo-img{max-height:40px;max-width:130px}
  .site-branding__name{font-size:16px}
  .site-header__cta{padding-inline:14px;font-size:12px;min-height:40px}
}

@media (max-width: 380px){
  .site-burger__label{display:none}
  .site-header__cta span{display:none}
  .site-header__cta{padding-inline:10px}
}

/* Hard reset bullets */
.site-menu, .site-menu ul,
.menu, .menu ul,
.site-offcanvas__menu, .site-offcanvas__menu ul,
.site-header__menu, .site-header__menu ul{
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
}

/* Offcanvas inner blocks */
.site-offcanvas__cta{padding:14px 16px 0}
.site-offcanvas__contact{
  padding:18px 16px 6px;
  border-top:1px solid var(--dag-border);
  margin-top:18px;
}
.site-offcanvas__contact-title{
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:11px;
  color:var(--dag-muted);
  margin-bottom:12px;
}
.site-offcanvas__pills{display:grid;gap:10px}

.site-pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:9px 14px;
  border-radius:var(--dag-radius-sm);
  border:1px solid var(--dag-border);
  background:var(--dag-surface);
  text-decoration:none;
  color:var(--dag-text);
  white-space:nowrap;
  width:100%;
  max-width:100%;
  transition:background var(--anim-fast) ease, border-color var(--anim-fast) ease, color var(--anim-fast) ease;
}
.site-pill__k{
  font-size:11px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--dag-muted);
  flex:0 0 auto;
}
.site-pill__v{font-weight:700;overflow:hidden;text-overflow:ellipsis}
.site-pill:hover{
  background:var(--dag-surface-2);
  border-color:var(--dag-primary);
  color:var(--dag-primary);
}

/* ═══════════ FOOTER (placeholder; mega footer in next phase) ═══════════ */
.site-footer{
  border-top:4px solid var(--dag-primary);
  background:var(--dag-secondary);
  color:var(--dag-secondary-contrast);
}
.site-footer a{color:var(--dag-secondary-contrast)}
.site-footer a:hover{color:var(--dag-accent)}
.site-footer__inner{
  padding-block:clamp(32px, 4vw, 48px);
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(18px, 2vw, 26px);
}
.footer-brand{
  font-family:var(--dag-font-display);
  font-weight:400;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:1.4rem;
  margin-bottom:10px;
  color:var(--dag-secondary-contrast);
}
.footer-contact-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.footer-label{color:var(--dag-accent);font-weight:700;margin-right:6px;letter-spacing:.06em;text-transform:uppercase;font-size:12px}
.site-footer__legal{display:flex;justify-content:center}
.footer-legal{
  list-style:none; margin:0; padding:0;
  display:flex; align-items:center; justify-content:center;
  gap:10px; flex-wrap:wrap;
}
.footer-legal a{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:40px; padding:9px 16px;
  border-radius:var(--dag-radius-sm);
  border:1px solid rgba(255,255,255,.18);
  background:transparent;
  color:var(--dag-secondary-contrast);
  text-decoration:none;
  font-weight:600; letter-spacing:.04em; text-transform:uppercase; font-size:12px;
  transition:background var(--anim-fast) ease, border-color var(--anim-fast) ease, color var(--anim-fast) ease;
}
.footer-legal a:hover{
  background:var(--dag-accent);
  border-color:var(--dag-accent);
  color:var(--dag-secondary);
}
.site-footer__copyright{color:rgba(255,255,255,.7);font-size:.9rem;text-align:center}

/* Branding mode override */
@media (max-width: 520px){
  .site-branding__home--text .site-branding__name{display:inline}
}
