/* DSU Intranet — Editorial v2 stylesheet */
:root {
  --dsu-navy: #002F6C;
  --dsu-navy-dark: #001F47;
  --dsu-navy-deep: #00112B;
  --dsu-blue: #009DDC;
  --dsu-blue-light: #B7E5F6;
  --dsu-red: #EE3124;
  --dsu-red-dark: #C8261B;
  --dsu-gold: #FFB81C;
  --dsu-cream: #FAF6EE;
  --bg: #F4F6F9;
  --surface: #FFFFFF;
  --surface-warm: #FBF9F5;
  --text: #15203A;
  --text-muted: #5A6A7E;
  --text-soft: #8696AB;
  --border: #E1E6EE;
  --border-soft: #EFF2F7;
  --hover: #EEF4FB;
  --shadow-sm: 0 1px 3px rgba(0,47,108,0.06);
  --shadow: 0 4px 14px rgba(0,47,108,0.08), 0 2px 6px rgba(0,47,108,0.04);
  --shadow-lg: 0 12px 40px rgba(0,47,108,0.12), 0 4px 12px rgba(0,47,108,0.06);
  --shadow-xl: 0 24px 60px rgba(0,47,108,0.18);
  --radius: 12px;
  --radius-lg: 18px;
  --max-w: 1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{height:100%}
body{
  font-family:'Inter','Helvetica Neue',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:var(--dsu-navy);text-decoration:none;transition:color .15s}
a:hover{color:var(--dsu-red)}
img{max-width:100%;display:block}

/* Typography utility classes (editorial display) */
.display-1{font-family:'Playfair Display','Georgia',serif;font-weight:800;font-size:clamp(38px,5.5vw,68px);line-height:1.02;letter-spacing:-1.2px}
.display-2{font-family:'Playfair Display','Georgia',serif;font-weight:800;font-size:clamp(30px,3.6vw,46px);line-height:1.08;letter-spacing:-0.6px}
.display-3{font-family:'Playfair Display','Georgia',serif;font-weight:700;font-size:clamp(24px,2.6vw,34px);line-height:1.15;letter-spacing:-0.3px}
.eyebrow{font-size:11px;font-weight:800;letter-spacing:2.4px;text-transform:uppercase;color:var(--dsu-red)}
.lead{font-size:17px;line-height:1.6;color:var(--text-muted);max-width:64ch}
.accent-gold{color:var(--dsu-gold)}
.accent-red{color:var(--dsu-red)}
.accent-blue{color:var(--dsu-blue)}

/* HEADER */
header.topbar{
  background:rgba(255,255,255,0.96);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  color:var(--text);
  padding:0 24px;
  display:flex;align-items:center;gap:20px;
  height:64px;
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100;
}
.brand,.brand:hover,.brand:visited{
  display:flex;align-items:center;gap:14px;
  font-weight:800;font-size:16px;letter-spacing:0.2px;
  white-space:nowrap;color:var(--dsu-navy);text-decoration:none;
}
.brand small{display:block;font-size:10px;letter-spacing:1.6px;font-weight:600;color:var(--dsu-red);margin-top:2px}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-logo{
  height:44px;width:auto;max-width:200px;
  object-fit:contain;object-position:left center;
  display:block;
  /* Crop to the leftmost portion of the flag/wordmark image if it has variants stacked side-by-side */
  border-radius:4px;
}
@media (max-width:900px){
  .brand-logo{height:36px;max-width:150px}
}
.topbar nav.main-menu{display:flex;gap:4px;margin-left:14px}
.topbar nav.main-menu a{
  padding:8px 14px;border-radius:999px;
  font-size:13px;font-weight:600;color:var(--text-muted);
  letter-spacing:0.3px;transition:all .15s;
}
.topbar nav.main-menu a:hover{background:var(--hover);color:var(--dsu-navy)}
.topbar-search{flex:1;max-width:380px;position:relative}
.topbar-search input{
  width:100%;padding:9px 14px 9px 36px;border:1px solid var(--border);
  border-radius:999px;background:var(--surface-warm);color:var(--text);font-size:13px;outline:none;
  transition:border-color .15s,box-shadow .15s;
}
.topbar-search input::placeholder{color:var(--text-soft)}
.topbar-search input:focus{border-color:var(--dsu-blue);box-shadow:0 0 0 3px rgba(0,157,220,.2);background:#fff}
.topbar-search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:16px;height:16px;opacity:.55;pointer-events:none}
.topbar-actions{display:flex;align-items:center;gap:6px}
.top-link{color:var(--text-muted);padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:all .15s}
.top-link:hover{background:var(--hover);color:var(--dsu-navy);text-decoration:none}
.top-link.cta{background:var(--dsu-navy);color:#fff}
.top-link.cta:hover{background:var(--dsu-red);color:#fff}

/* LAYOUT */
.layout{display:flex;min-height:calc(100vh - 64px)}

/* SIDEBAR */
nav.sidebar{
  width:280px;flex:0 0 280px;background:var(--surface);border-right:1px solid var(--border);
  overflow-y:auto;padding:18px 0;position:sticky;top:64px;height:calc(100vh - 64px);
}
.sidebar-heading{font-size:10.5px;font-weight:800;letter-spacing:1.6px;color:var(--text-soft);text-transform:uppercase;padding:18px 22px 8px}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:11px 22px;
  cursor:pointer;user-select:none;border-left:3px solid transparent;color:var(--text);
  font-size:14px;font-weight:600;text-decoration:none;transition:all .12s;
}
.nav-item:hover{background:var(--hover);text-decoration:none;color:var(--text)}
.nav-item.active{background:linear-gradient(90deg,rgba(0,157,220,.1),transparent);border-left-color:var(--dsu-red);color:var(--dsu-navy)}
.nav-item svg{width:18px;height:18px;flex-shrink:0;opacity:.75}
.nav-item.active svg{color:var(--dsu-red);opacity:1}
.nav-count{margin-left:auto;font-size:11px;background:var(--border-soft);color:var(--text-muted);padding:2px 8px;border-radius:999px;font-weight:700;letter-spacing:0.2px}
.nav-item.active .nav-count{background:var(--dsu-red);color:#fff}
.nav-toggle{margin-left:auto;width:14px;height:14px;transition:transform .2s}
.nav-item.open .nav-toggle{transform:rotate(90deg)}
.nav-sublist{display:none;background:rgba(0,47,108,.02);margin-left:28px;padding:4px 0;border-left:1px solid var(--border-soft)}
.nav-sublist.open{display:block}
.nav-subgroup{font-size:10px;font-weight:800;letter-spacing:1.2px;color:var(--text-soft);text-transform:uppercase;padding:10px 16px 4px}
.nav-sublink{display:block;padding:7px 16px;font-size:13px;color:var(--text-muted);text-decoration:none;line-height:1.4;border-left:2px solid transparent}
.nav-sublink:hover{background:var(--hover);color:var(--dsu-navy);text-decoration:none;border-left-color:var(--dsu-blue)}
.nav-sublink.active{color:var(--dsu-red);font-weight:700;background:rgba(238,49,36,.06);border-left-color:var(--dsu-red)}

/* MAIN */
main.content{flex:1;overflow-x:hidden;background:var(--bg)}
.content-wrap{max-width:var(--max-w);margin:0 auto;padding:32px 40px}
.content-wrap.narrow{max-width:920px}
.content-wrap.tight{max-width:760px}

/* Breadcrumbs */
.breadcrumb{font-size:12px;color:var(--text-muted);margin-bottom:14px;letter-spacing:0.4px;text-transform:uppercase;font-weight:600}
.breadcrumb a{color:var(--text-muted)}
.breadcrumb a:hover{color:var(--dsu-red)}
.breadcrumb span{color:var(--text);font-weight:700}
.breadcrumb-sep{padding:0 8px;color:var(--text-soft)}

/* ============ HOME HERO (full-bleed magazine) ============ */
.hero-magazine{
  position:relative;
  height:min(560px, 80vh);
  min-height:440px;
  margin:0;
  overflow:hidden;
  background:#001;
  color:#fff;
}
.hero-magazine::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(135deg,rgba(0,17,43,0.78) 0%,rgba(0,47,108,0.55) 40%,rgba(0,17,43,0.35) 70%,rgba(0,17,43,0.85) 100%),url('img/p15.jpg');
  background-size:cover;background-position:center 30%;
}
.hero-magazine::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:120px;
  background:linear-gradient(to bottom,transparent,var(--bg));
  pointer-events:none;
}
.hero-magazine .hero-inner{
  position:relative;z-index:2;max-width:var(--max-w);
  margin:0 auto;padding:80px 40px 70px;height:100%;
  display:flex;flex-direction:column;justify-content:center;
}
.hero-magazine .eyebrow{color:var(--dsu-gold);margin-bottom:16px}
.hero-magazine h1{color:#fff;max-width:14ch;margin-bottom:18px}
.hero-magazine h1 .accent{color:var(--dsu-gold)}
.hero-magazine .lead{color:rgba(255,255,255,.92);max-width:54ch;margin-bottom:26px;font-size:18px}
.hero-cta-row{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary{background:var(--dsu-red);color:#fff;padding:12px 22px;border-radius:999px;font-size:14px;font-weight:700;letter-spacing:.3px;display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;transition:all .15s;text-decoration:none}
.btn-primary:hover{background:var(--dsu-red-dark);transform:translateY(-1px);color:#fff;text-decoration:none}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.4);padding:12px 22px;border-radius:999px;font-size:14px;font-weight:700;display:inline-flex;align-items:center;gap:8px;transition:all .15s;backdrop-filter:blur(8px);text-decoration:none}
.btn-ghost:hover{background:rgba(255,255,255,.18);color:#fff;border-color:#fff;text-decoration:none}

/* Quick icon strip below hero (UW style) */
.quick-strip{
  background:var(--surface);max-width:var(--max-w);margin:24px auto 0;
  border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);position:relative;z-index:5;
  padding:18px 24px;
  display:grid;grid-template-columns:repeat(6, minmax(0,1fr));
  gap:8px;
}
.quick-strip a{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  padding:14px 8px;border-radius:10px;color:var(--text-muted);text-decoration:none;
  font-size:11px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;text-align:center;
  transition:all .15s;
}
.quick-strip a svg{width:28px;height:28px;color:var(--dsu-navy);transition:color .15s}
.quick-strip a:hover{background:var(--hover);color:var(--dsu-navy);text-decoration:none}
.quick-strip a:hover svg{color:var(--dsu-red)}

/* ============ Section heading (Bellevue style) ============ */
.section-block{padding:64px 0}
.section-block.tight{padding:40px 0}
.section-head{margin-bottom:32px;display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.section-head h2{font-family:'Playfair Display','Georgia',serif;font-size:clamp(28px,3.3vw,42px);font-weight:800;line-height:1.06;color:var(--dsu-navy);letter-spacing:-0.4px;max-width:18ch}
.section-head h2 .accent{color:var(--dsu-red)}
.section-head h2 .accent-gold{color:var(--dsu-gold)}
.section-head .lead{max-width:42ch}
.section-link{font-size:13px;font-weight:700;color:var(--dsu-blue);display:inline-flex;align-items:center;gap:6px;letter-spacing:.3px;text-transform:uppercase}
.section-link:hover{color:var(--dsu-red)}

/* Audience pair (Faculty + Staff): big photo cards with sub-links */
.audience-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:22px}
.audience-card{
  background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:all .25s;
}
.audience-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.audience-card .photo{height:200px;background-size:cover;background-position:center;position:relative}
.audience-card .photo::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,transparent 60%,rgba(0,17,43,.55))}
.audience-card .photo .audience-badge{position:absolute;left:18px;bottom:14px;z-index:2;color:#fff;font-family:'Playfair Display','Georgia',serif;font-size:28px;font-weight:800;letter-spacing:-0.3px}
.audience-card .body{padding:22px 24px 24px}
.audience-card .body p{font-size:14px;color:var(--text-muted);margin-bottom:14px;line-height:1.55}
.audience-card .body ul{list-style:none;border-top:1px solid var(--border-soft);padding-top:14px}
.audience-card .body li{margin-bottom:9px}
.audience-card .body li a{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}
.audience-card .body li a::before{content:"›";color:var(--dsu-red);font-weight:800;font-size:16px}
.audience-card .body li a:hover{color:var(--dsu-red)}

/* News / announcements row (UW style) */
.news-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:22px}
.news-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:all .22s}
.news-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);text-decoration:none;color:inherit}
.news-card .photo{height:170px;background-size:cover;background-position:center}
.news-card .body{padding:18px 22px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.news-card .tag{font-size:10.5px;font-weight:800;letter-spacing:1.6px;color:var(--dsu-red);text-transform:uppercase}
.news-card h3{font-size:18px;font-weight:700;color:var(--dsu-navy);line-height:1.25;font-family:'Playfair Display','Georgia',serif}
.news-card p{font-size:13px;color:var(--text-muted);line-height:1.55}
.news-card time{font-size:11px;color:var(--text-soft);font-style:italic;margin-top:auto;padding-top:8px}
.news-card.pinned .tag::before{content:"📌 ";font-style:normal}

/* Mosaic — featured big + 4 small */
.mosaic{display:grid;grid-template-columns:1.6fr 1fr;gap:22px}
.mosaic .feature{
  background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;
  background-size:cover;background-position:center;min-height:420px;
  position:relative;color:#fff;display:flex;flex-direction:column;justify-content:flex-end;
  text-decoration:none;
}
.mosaic .feature::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,17,43,.05) 40%,rgba(0,17,43,.92))}
.mosaic .feature .body{position:relative;z-index:2;padding:30px 32px}
.mosaic .feature .tag{font-size:11px;font-weight:800;letter-spacing:1.8px;color:var(--dsu-gold);text-transform:uppercase}
.mosaic .feature h3{font-family:'Playfair Display','Georgia',serif;font-size:34px;font-weight:800;color:#fff;line-height:1.06;margin:8px 0 10px;letter-spacing:-0.4px}
.mosaic .feature p{color:rgba(255,255,255,.9);font-size:14px;max-width:46ch}
.mosaic .feature:hover{text-decoration:none}
.mosaic-col{display:grid;grid-template-rows:repeat(4,1fr);gap:14px}
.mosaic-tile{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px;display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;transition:all .15s;
}
.mosaic-tile:hover{border-color:var(--dsu-blue);transform:translateX(2px);text-decoration:none;color:inherit;box-shadow:var(--shadow-sm)}
.mosaic-tile .icon{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--dsu-navy),var(--dsu-blue));color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mosaic-tile .icon svg{width:22px;height:22px}
.mosaic-tile .info{min-width:0}
.mosaic-tile .info h4{font-size:15px;font-weight:700;color:var(--dsu-navy);margin-bottom:2px}
.mosaic-tile .info p{font-size:12px;color:var(--text-muted)}
.mosaic-tile .meta{margin-left:auto;font-size:11px;font-weight:700;color:var(--dsu-red);background:rgba(238,49,36,.08);padding:4px 10px;border-radius:999px;letter-spacing:.4px}

/* 50/50 editorial split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split.reverse{direction:rtl}
.split.reverse > *{direction:ltr}
.split .text h3{font-family:'Playfair Display','Georgia',serif;font-size:30px;font-weight:800;color:var(--dsu-navy);line-height:1.1;letter-spacing:-0.3px;margin-bottom:14px}
.split .text h3 .accent{color:var(--dsu-red)}
.split .text p{font-size:15px;color:var(--text-muted);line-height:1.6;margin-bottom:14px}
.split .text ul{list-style:none;margin-bottom:20px}
.split .text ul li{padding:8px 0;border-bottom:1px solid var(--border-soft);font-size:14px}
.split .text ul li a{font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}
.split .text ul li a::after{content:"→";margin-left:auto;color:var(--dsu-red);font-weight:800;opacity:.65;transition:transform .15s}
.split .text ul li a:hover::after{transform:translateX(4px);opacity:1}
.split .text ul li a:hover{color:var(--dsu-red)}
.split .visual{position:relative}
.split .visual img,.split .visual .photo{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);height:380px;background-size:cover;background-position:center;display:block}
.split .visual .badge{position:absolute;left:-20px;top:30px;background:var(--dsu-gold);color:var(--dsu-navy);font-weight:800;font-size:11px;padding:8px 14px;border-radius:999px;letter-spacing:1px;text-transform:uppercase;box-shadow:var(--shadow)}

/* Color band (full-bleed) */
.colorband{background:linear-gradient(120deg,var(--dsu-navy) 0%, var(--dsu-navy-dark) 40%, #00498F 100%);color:#fff;padding:64px 40px;position:relative;overflow:hidden}
.colorband::before{content:"";position:absolute;right:-100px;top:-100px;width:340px;height:340px;background:radial-gradient(circle,rgba(255,184,28,.22),transparent 70%);border-radius:50%}
.colorband::after{content:"";position:absolute;left:-60px;bottom:-60px;width:240px;height:240px;background:radial-gradient(circle,rgba(238,49,36,.22),transparent 70%);border-radius:50%}
.colorband .inner{max-width:var(--max-w);margin:0 auto;position:relative;z-index:2;display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.colorband h2{font-family:'Playfair Display','Georgia',serif;font-size:38px;font-weight:800;color:#fff;letter-spacing:-0.4px;line-height:1.08;margin-bottom:14px}
.colorband h2 .accent{color:var(--dsu-gold)}
.colorband .lead{color:rgba(255,255,255,.92);max-width:48ch}
.colorband .stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.colorband .stat{background:rgba(255,255,255,.06);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:22px}
.colorband .stat strong{display:block;font-family:'Playfair Display','Georgia',serif;font-size:42px;color:var(--dsu-gold);font-weight:800;letter-spacing:-1px}
.colorband .stat small{display:block;font-size:11px;letter-spacing:1.5px;color:rgba(255,255,255,.78);text-transform:uppercase;margin-top:4px}

/* ============ ARTICLE / CONTENT PAGE ============ */
article.page-article{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;margin-bottom:32px}

/* Article hero with photo banner */
.article-hero{position:relative;padding:0;overflow:hidden}
.article-hero .photo-band{height:240px;background-size:cover;background-position:center;position:relative}
.article-hero .photo-band::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,47,108,.65),rgba(0,17,43,.4) 60%,rgba(0,157,220,.35))}
.article-hero .photo-band.no-photo{background:linear-gradient(135deg,var(--dsu-navy),#003E8C 70%, var(--dsu-blue));height:auto;min-height:140px}
.article-hero .photo-band.no-photo::after{display:none}
.article-hero .photo-band-content{position:absolute;left:36px;right:36px;bottom:22px;z-index:2;color:#fff}
.article-hero .photo-band-content .eyebrow{color:var(--dsu-gold);margin-bottom:6px}
.article-hero h1{font-family:'Playfair Display','Georgia',serif;font-size:clamp(28px,3.6vw,44px);font-weight:800;color:#fff;letter-spacing:-0.5px;line-height:1.06;max-width:24ch}
.article-hero .lead-card{padding:24px 36px 22px;background:var(--surface);border-bottom:1px solid var(--border-soft)}
.article-hero .lead-card .lead{font-size:17px;color:var(--text-muted);max-width:64ch}
.article-meta{display:flex;flex-wrap:wrap;gap:16px;margin-top:14px;font-size:12px;color:var(--text-muted)}
.article-meta span{display:inline-flex;align-items:center;gap:6px}
.article-meta svg{width:14px;height:14px;opacity:.7}

.article-body{padding:34px 40px 40px;font-size:16px;line-height:1.75;color:#2c3947}
.article-body h2{font-family:'Playfair Display','Georgia',serif;font-size:26px;color:var(--dsu-navy);margin:32px 0 12px;font-weight:700;letter-spacing:-0.2px;padding-bottom:6px;border-bottom:2px solid var(--dsu-gold);display:inline-block}
.article-body h2:first-child{margin-top:0}
.article-body h3{font-size:18px;color:var(--dsu-navy);margin:22px 0 8px;font-weight:700}
.article-body h4{font-size:15px;color:var(--text);margin:16px 0 6px;font-weight:700}
.article-body p{margin-bottom:14px;line-height:1.75;color:#2c3947}
.article-body ul,.article-body ol{margin:8px 0 18px 24px}
.article-body li{margin-bottom:6px;line-height:1.65}
.article-body strong{font-weight:700;color:var(--dsu-navy)}
.article-body a{color:var(--dsu-blue);text-decoration:underline;text-decoration-color:rgba(0,157,220,.4);text-underline-offset:3px;text-decoration-thickness:1.5px}
.article-body a:hover{color:var(--dsu-red);text-decoration-color:var(--dsu-red)}
.article-body blockquote{border-left:4px solid var(--dsu-blue);background:linear-gradient(to right,rgba(0,157,220,.05),transparent);padding:14px 20px;margin:18px 0;font-style:italic;color:var(--text)}

/* Pull-quote callout */
.callout{background:var(--surface-warm);border-left:4px solid var(--dsu-red);border-radius:0 10px 10px 0;padding:18px 22px;margin:20px 0}
.callout .label{font-size:11px;font-weight:800;letter-spacing:1.4px;color:var(--dsu-red);text-transform:uppercase;margin-bottom:6px}
.callout p{font-size:15px;color:var(--text);margin:0;line-height:1.6}

/* Article aside */
.article-aside{background:rgba(0,157,220,.04);border:1px solid rgba(0,157,220,.2);border-radius:10px;padding:18px 22px;margin:18px 0}
.article-aside h3{font-size:13px;color:var(--dsu-navy);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;font-weight:800}
.article-aside ul{margin:0;padding-left:18px}
.article-aside li{margin-bottom:4px;font-size:14px}

/* ============ Files / forms section ============ */
.files-section{margin-top:28px}
.files-section h2{font-family:'Playfair Display','Georgia',serif;font-size:22px;color:var(--dsu-navy);margin-bottom:12px;display:flex;align-items:center;gap:10px;font-weight:700}
.files-section .count{font-size:11px;font-weight:700;color:var(--dsu-red);background:rgba(238,49,36,.08);padding:3px 10px;border-radius:999px;letter-spacing:.4px;text-transform:uppercase}
.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}
.file-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;text-decoration:none;color:inherit;transition:all .15s}
.file-card:hover{border-color:var(--dsu-blue);box-shadow:var(--shadow-sm);transform:translateX(2px);text-decoration:none;color:inherit}
.file-icon{width:40px;height:48px;border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;font-weight:800;color:#fff;letter-spacing:0.4px;box-shadow:0 2px 4px rgba(0,0,0,.1)}
.file-icon.pdf{background:#D93025}
.file-icon.doc{background:#1A73E8}
.file-icon.xls{background:#188038}
.file-icon.ppt{background:#C2410C}
.file-icon.zip{background:#6B7280}
.file-icon.form{background:var(--dsu-navy)}
.file-icon.link{background:var(--dsu-blue)}
.file-info{flex:1;min-width:0}
.file-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.35;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.file-card:hover .file-name{color:var(--dsu-red)}
.file-meta{font-size:11px;color:var(--text-soft);letter-spacing:.3px}

/* Article layout with sidebar */
.article-layout{display:grid;grid-template-columns:1fr 300px;gap:28px}
.related-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.related-card h3{padding:14px 18px;background:linear-gradient(135deg,var(--dsu-navy),var(--dsu-navy-dark));color:#fff;font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase}
.related-card ul{list-style:none;padding:8px 0}
.related-card li a{display:block;padding:10px 18px;font-size:13px;color:var(--text);border-left:2px solid transparent;line-height:1.4}
.related-card li a:hover{background:var(--hover);border-left-color:var(--dsu-red);color:var(--dsu-navy);text-decoration:none}
.related-card li a.active{background:var(--hover);border-left-color:var(--dsu-red);color:var(--dsu-red);font-weight:700}

/* Audience tags (inline pills) */
.audience-tag{display:inline-flex;align-items:center;padding:3px 9px;font-size:10px;font-weight:800;letter-spacing:.5px;border-radius:999px;text-transform:uppercase;line-height:1.4}
.audience-tag.faculty{background:#EEE6F7;color:#5B2A86}
.audience-tag.staff{background:#E5F4EB;color:#1E7A3F}
.audience-tag.students{background:#FDE6E4;color:#B82218}

/* Tables */
.article-body table{width:100%;border-collapse:collapse;margin:14px 0;font-size:14px}
.article-body th,.article-body td{padding:10px 14px;border:1px solid var(--border);text-align:left}
.article-body th{background:var(--surface-warm);color:var(--dsu-navy);font-weight:700}
.article-body tr:nth-child(even) td{background:rgba(0,47,108,.02)}

/* Policy TOC */
.policy-toc{background:var(--surface-warm);border:1px solid var(--border);border-radius:10px;padding:18px 22px;margin:20px 0}
.policy-toc h3{font-size:11px;color:var(--dsu-navy);margin-bottom:8px;text-transform:uppercase;letter-spacing:1.2px;font-weight:800}
.policy-toc ol{list-style:decimal;padding-left:24px;margin:0}
.policy-toc li{font-size:13.5px;margin-bottom:5px;color:var(--text)}
.policy-toc li a{color:var(--text)}
.policy-toc li a:hover{color:var(--dsu-red)}

/* Directory grid */
.directory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.directory-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:4px;transition:all .15s}
.directory-card:hover{box-shadow:var(--shadow);border-color:var(--dsu-blue)}
.directory-card .name{font-weight:700;color:var(--dsu-navy);font-size:16px}
.directory-card .title{font-size:13px;color:var(--text-muted);margin-bottom:6px}
.directory-card .contact{font-size:12.5px;color:var(--text)}
.directory-card .contact a{color:var(--dsu-blue)}

/* Footer */
footer.footer{
  padding:34px 40px;background:var(--dsu-navy-dark);color:rgba(255,255,255,.78);
  text-align:center;font-size:12.5px;line-height:1.7;
  border-top:6px solid var(--dsu-red);margin-top:60px;
}
footer.footer strong{color:#fff;font-family:'Playfair Display','Georgia',serif;font-size:16px;font-weight:700;display:block;margin-bottom:4px}
footer.footer a{color:var(--dsu-gold)}
footer.footer .canonical-link{display:block;margin-top:14px;font-size:11px;opacity:.65}
footer.footer .canonical-link a{color:var(--dsu-blue-light)}

/* Mobile menu button */
.mobile-menu-btn{display:none;background:none;border:none;color:var(--dsu-navy);cursor:pointer;padding:8px}

/* Print */
@media print{
  header.topbar,nav.sidebar,.article-aside,footer.footer,.hero-magazine,.quick-strip,.colorband{display:none !important}
  main.content{padding:0}
  article.page-article{box-shadow:none;border:none}
  .article-layout{grid-template-columns:1fr}
}

/* Responsive */
@media (max-width:1100px){
  .news-grid{grid-template-columns:repeat(2,1fr)}
  .mosaic{grid-template-columns:1fr}
  .mosaic-col{grid-template-rows:auto}
  .split,.colorband .inner{grid-template-columns:1fr;gap:30px}
  .article-layout{grid-template-columns:1fr}
}
@media (max-width:900px){
  .mobile-menu-btn{display:flex}
  .topbar-search{max-width:none}
  .topbar nav.main-menu{display:none}
  nav.sidebar{position:fixed;left:-320px;top:64px;transition:left .2s;z-index:50;box-shadow:var(--shadow-xl)}
  nav.sidebar.open{left:0}
  .content-wrap{padding:20px}
  .audience-grid,.news-grid{grid-template-columns:1fr}
  .top-link.hide-mobile{display:none}
  .quick-strip{grid-template-columns:repeat(3,1fr);margin:18px 16px 0}
  .article-body{padding:24px 22px}
  .hero-magazine .hero-inner{padding:60px 20px 50px}
}
