/* 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;
  height:var(--crwda-logo-size, 48px);
  max-height:var(--crwda-logo-size, 48px);
  width:auto;
  max-width:clamp(140px, 14vw, 240px);
  object-fit:contain;
  transition:height .15s ease;
}

.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__name{font-size:16px}
  .site-header__cta{padding-inline:10px;font-size:0;min-height:40px;gap:0;min-width:40px;justify-content:center}
  .site-header__cta span{display:none}
  .site-header__cta .site-header__cta-ico{font-size:initial}
  .site-burger__label{display:none}
}

@media (max-width: 380px){
  .site-header__cta{padding-inline:8px}
}

/* 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}
}

/* ═══════════ MEGA FOOTER ═══════════ */
.site-mega-footer{padding-top:0}
.site-mega-footer__grid{
  display:grid;
  grid-template-columns:minmax(0, 1.3fr) minmax(0, 1.2fr) minmax(0, .9fr) minmax(0, .9fr);
  gap:clamp(24px, 3vw, 40px);
  padding-block:clamp(40px, 4vw, 64px);
}

.site-mega-footer__col--map .footer-map{
  position:relative;
  aspect-ratio:4/3;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  overflow:hidden;
  min-height:220px;
}
.site-mega-footer__col--map .footer-map iframe{
  position:absolute; inset:0;
  width:100%; height:100%;
  border:0;
  display:block;
  filter:grayscale(.3) contrast(1.05);
}

.footer-brand{
  font-family:var(--dag-font-display);
  font-weight:400;
  font-size:1.6rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--dag-sec-dark-fg);
  margin:0 0 12px;
  padding-bottom:12px;
  border-bottom:3px solid var(--dag-accent);
  display:inline-block;
}

.footer-brand__tag{
  color:rgba(255,255,255,.72);
  font-size:14px;
  line-height:1.5;
  margin:0 0 20px;
  max-width:34ch;
}

.footer-contact-list{
  list-style:none;
  padding:0; margin:0;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.footer-contact-list li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:14px;
  line-height:1.5;
  color:rgba(255,255,255,.88);
}
.footer-contact-list a{
  color:var(--dag-sec-dark-fg);
  text-decoration:none;
}
.footer-contact-list a:hover{color:var(--dag-accent);text-decoration:underline}
.footer-ico{
  flex:0 0 auto;
  color:var(--dag-accent);
  display:inline-flex;
  align-items:center;
  margin-top:2px;
}

.footer-colhead{
  font-family:var(--dag-font-display);
  font-weight:400;
  font-size:15px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--dag-accent);
  margin:0 0 16px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,.16);
}

.footer-hours{
  margin:0 0 18px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:6px 12px;
  font-size:14px;
}
.footer-hours dt{color:rgba(255,255,255,.72);font-weight:500}
.footer-hours dd{margin:0;color:var(--dag-sec-dark-fg);font-weight:600;text-align:right}

.footer-hours-line{color:rgba(255,255,255,.84);margin:0 0 18px}

.footer-nav{
  list-style:none;
  padding:0; margin:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.footer-nav a{
  color:rgba(255,255,255,.88);
  text-decoration:none;
  font-size:14px;
  font-weight:500;
  letter-spacing:.02em;
  transition:color var(--anim-fast) ease;
}
.footer-nav a:hover{color:var(--dag-accent)}

/* ─── Bottom bar ─── */
.site-footer__bottom{
  border-top:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.25);
  padding-block:16px;
}
.site-footer__bottom-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.site-footer__copyright{
  color:rgba(255,255,255,.6);
  font-size:12.5px;
  margin:0;
  text-align:left;
}
.footer-legal{
  list-style:none;
  padding:0; margin:0;
  display:flex;
  gap:20px;
  flex-wrap:wrap;
}
.footer-legal a{
  color:rgba(255,255,255,.7);
  font-size:12.5px;
  text-transform:none;
  letter-spacing:0;
  padding:0;
  border:0;
  background:transparent;
  min-height:0;
  font-weight:500;
  border-radius:0;
}
.footer-legal a:hover{background:transparent;border:0;color:var(--dag-accent)}

/* Responsive */
@media (max-width: 1020px){
  .site-mega-footer__grid{
    grid-template-columns:1fr 1fr;
  }
  .site-mega-footer__col--map{grid-column:1 / -1}
}
@media (max-width: 620px){
  .site-mega-footer__grid{grid-template-columns:1fr}
  .site-footer__bottom-inner{flex-direction:column;align-items:center;gap:10px;text-align:center}
  .site-footer__copyright{text-align:center}
}

/* ─── NT header (3-row: utility · logo · nav) ─── */
.nt-header { background: #fff; border-bottom: 1px solid var(--nt-silver-2, #E6ECF3); font-family: var(--dag-font); }
.nt-utility { background: var(--nt-silver-3, #F5F8FC); border-bottom: 1px solid var(--nt-silver-2, #E6ECF3); font-size: 12px; }
.nt-utility__inner { max-width: 1200px; margin: 0 auto; padding: 8px 28px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.nt-utility__left { display: flex; align-items: center; gap: 20px; color: var(--nt-muted, #5B6B82); flex-wrap: wrap; }
.nt-utility__right { display: flex; align-items: center; gap: 18px; color: var(--nt-navy, #1D2951); font-weight: 500; }
.nt-util-item { display: inline-flex; align-items: center; gap: 6px; text-decoration: none; color: inherit; }
.nt-util-item svg { flex-shrink: 0; }
.nt-util-item--phone { color: var(--nt-red, #B22234); font-weight: 600; }
.nt-util-item--phone:hover { color: var(--nt-red-600, #951B2B); }
.nt-util-item--email:hover { color: var(--nt-navy, #1D2951); }

.nt-logo-row { padding: 18px 28px; display: flex; align-items: center; justify-content: center; border-bottom: 1px solid var(--nt-silver-2, #E6ECF3); }
.nt-logo { display: inline-flex; align-items: center; text-decoration: none; color: inherit; line-height: 0; }
.nt-logo img, .nt-logo .custom-logo { max-height: 70px; width: auto; display: block; }
.nt-logo__fallback { display: inline-flex; align-items: baseline; gap: 14px; font-family: Georgia, "Times New Roman", serif; font-weight: 700; letter-spacing: -1px; }
.nt-logo__name-1 { font-size: 28px; color: var(--nt-navy, #1D2951); }
.nt-logo__name-2 { font-size: 28px; color: var(--nt-red, #B22234); }

.nt-nav { background: #fff; }
.nt-nav__inner { max-width: 1200px; margin: 0 auto; padding: 0 28px; display: flex; align-items: center; justify-content: center; }
.nt-nav__menu { list-style: none; margin: 0; padding: 0; display: flex; gap: 32px; align-items: center; }
.nt-nav__menu li { position: relative; }
.nt-nav__menu a { display: block; padding: 14px 0; font-size: 13px; color: var(--nt-ink-2, #1F2A44); font-weight: 500; letter-spacing: 1px; text-transform: uppercase; text-decoration: none; transition: color .16s; position: relative; }
.nt-nav__menu a:hover { color: var(--nt-red, #B22234); }
.nt-nav__menu .current-menu-item > a, .nt-nav__menu .current_page_item > a { color: var(--nt-navy, #1D2951); }
.nt-nav__menu .current-menu-item > a::after, .nt-nav__menu .current_page_item > a::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: var(--nt-red, #B22234); }

.nt-nav__toggle { display: none; background: none; border: 0; font-size: 14px; padding: 14px 0; color: var(--nt-navy, #1D2951); font-family: inherit; cursor: pointer; align-items: center; gap: 8px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; }

@media (max-width: 960px) {
  .nt-utility__inner { padding: 8px 18px; font-size: 11px; gap: 6px; }
  .nt-utility__left { gap: 10px; }
  .nt-utility__right { gap: 10px; }
  .nt-util-item--hours, .nt-util-item--email { display: none; }
  .nt-logo-row { padding: 14px 18px; }
  .nt-logo img, .nt-logo .custom-logo { max-height: 48px; }
  .nt-logo__name-1, .nt-logo__name-2 { font-size: 22px; }
  .nt-nav__inner { padding: 0 18px; justify-content: flex-start; }
  .nt-nav__toggle { display: inline-flex; }
  .nt-nav__menu { display: none; position: absolute; top: 100%; left: 0; right: 0; background: #fff; flex-direction: column; gap: 0; padding: 8px 18px 16px; border-bottom: 1px solid var(--nt-silver-2, #E6ECF3); z-index: 20; }
  .nt-nav__menu.is-open { display: flex; }
  .nt-nav__menu a { padding: 12px 0; }
}

/* ─── NT footer ─── */
.nt-footer { background: var(--nt-navy-700, #0E172E); color: #C9D2DD; padding: 44px 28px 28px; font-size: 13px; font-family: var(--dag-font); }
.nt-footer__inner { display: grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: 32px; max-width: 1100px; margin: 0 auto; }
.nt-footer__brand { font-family: var(--dag-font-display); font-size: 18px; color: #fff; margin-bottom: 10px; text-transform: uppercase; letter-spacing: .5px; font-weight: 400; }
.nt-footer__addr { line-height: 1.7; }
.nt-footer__addr a { color: inherit; text-decoration: none; }
.nt-footer__addr a:hover { color: #fff; }
.nt-footer__head { color: #fff; font-weight: 500; margin-bottom: 10px; font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; }
.nt-footer__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.nt-footer__list a { color: inherit; text-decoration: none; }
.nt-footer__list a:hover { color: #fff; }
.nt-footer__hours { line-height: 1.7; }
.nt-footer__bottom { max-width: 1100px; margin: 28px auto 0; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.08); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; font-size: 12px; color: #8795AB; }
.nt-footer__legal { display: flex; gap: 16px; }
.nt-footer__legal a { color: inherit; text-decoration: none; }
.nt-footer__legal a:hover { color: #fff; }

@media (max-width: 720px) {
  .nt-footer__inner { grid-template-columns: 1fr 1fr; gap: 24px; }
  .nt-footer__col--brand { grid-column: 1 / -1; }
  .nt-footer__bottom { flex-direction: column; align-items: flex-start; }
}

/* ─── NT nav: 3-col grid (toggle left · menu center · CTA right) ─── */
.nt-nav__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 16px;
  justify-content: stretch;
}
.nt-nav__inner > .nt-nav__toggle { grid-column: 1; justify-self: start; }
.nt-nav__inner > .nt-nav__menu   { grid-column: 2; justify-self: center; }
.nt-nav__inner > .nt-nav__cta    { grid-column: 3; justify-self: end; }
.nt-nav__cta .nt-btn {
  font-size: 12px; padding: 9px 18px; letter-spacing: .5px;
  text-transform: uppercase; font-weight: 500;
  box-shadow: 0 4px 14px rgba(178,34,52,.24);
}
.nt-nav__cta .nt-btn:hover {
  box-shadow: 0 6px 18px rgba(178,34,52,.38);
  transform: translateY(-1px);
}

@media (max-width: 1100px) {
  .nt-nav__inner { grid-template-columns: auto 1fr auto; }
  .nt-nav__inner > .nt-nav__menu { justify-self: start; padding-left: 4px; }
}
@media (max-width: 960px) {
  .nt-nav__cta .nt-btn { font-size: 11px; padding: 7px 12px; letter-spacing: 0; }
  .nt-nav__cta .nt-btn span { display: none; }
}
@media (max-width: 520px) {
  .nt-nav__cta { display: none; }
}
