/*
Theme Name: CSM Premium
Theme URI: https://thecosmeticsurgerymagazine.com
Author: The Cosmetic Surgery Magazine
Author URI: https://thecosmeticsurgerymagazine.com
Description: A luxury editorial theme for The Cosmetic Surgery Magazine — where precision meets beauty.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: magazine, news, editorial, premium, luxury
Text Domain: csm-premium
*/

/* ============================================
   ROOT VARIABLES
   ============================================ */
:root {
  --ivory:       #FAFAF8;
  --black:       #0D0D0D;
  --gold:        #C4A882;
  --gold-dark:   #9A7D5A;
  --rose:        #8B3A5C;
  --parchment:   #EDE9E2;
  --charcoal:    #2A2A2A;
  --muted:       #6B6B6B;
  --border:      #D9D4CD;
  --font-display:'Cormorant Garamond', Georgia, serif;
  --font-body:   'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --max-width:   1280px;
  --ease:        0.25s ease;
}

/* ============================================
   RESET & BASE
   ============================================ */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; }
body {
  background:var(--ivory);
  color:var(--black);
  font-family:var(--font-body);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
a { color:inherit; text-decoration:none; transition:color var(--ease); }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
input, button { font-family:var(--font-body); }

/* ============================================
   UTILITIES
   ============================================ */
.csm-container { max-width:var(--max-width); margin:0 auto; padding:0 40px; }
.csm-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.csm-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:32px; }
.csm-sr-only { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }

/* ============================================
   TOP BAR
   ============================================ */
.csm-topbar {
  background:var(--black);
  padding:9px 0;
  font-size:10.5px;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.csm-topbar .csm-container { display:flex; align-items:center; justify-content:space-between; }
.csm-topbar-date { color:#666; }
.csm-topbar-social { display:flex; gap:18px; }
.csm-topbar-social a { color:#666; font-size:10px; }
.csm-topbar-social a:hover { color:var(--gold); }
.csm-topbar-contact { display:flex; gap:20px; }
.csm-topbar-contact a { color:#666; font-size:10px; }
.csm-topbar-contact a:hover { color:var(--gold); }

/* ============================================
   MASTHEAD
   ============================================ */
.csm-masthead {
  background:var(--ivory);
  padding:38px 0 28px;
  border-bottom:1px solid var(--border);
}
.csm-masthead .csm-container { display:flex; align-items:center; justify-content:space-between; gap:20px; }
.csm-masthead-center { flex:1; text-align:center; }
.csm-logo { display:inline-block; }
.csm-logo-text {
  font-family:var(--font-display);
  font-size:36px;
  font-weight:300;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--black);
  line-height:1;
  display:block;
}
.csm-logo-rule { width:52px; height:1px; background:var(--gold); margin:11px auto; }
.csm-logo-tagline {
  font-family:var(--font-display);
  font-style:italic;
  font-size:14px;
  color:var(--muted);
  letter-spacing:.04em;
}
.csm-masthead-search { width:160px; display:flex; justify-content:flex-end; align-items:center; }
.csm-search-toggle {
  background:none;
  border:1px solid var(--border);
  padding:9px 18px;
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
  color:var(--muted);
  transition:all var(--ease);
}
.csm-search-toggle:hover { border-color:var(--black); color:var(--black); }
.csm-masthead-side { width:160px; }

/* Search bar */
.csm-search-bar {
  display:none;
  background:var(--parchment);
  border-bottom:1px solid var(--border);
  padding:16px 0;
}
.csm-search-bar.is-open { display:block; }
.csm-search-bar .search-form { display:flex; gap:0; max-width:500px; margin:0 auto; }
.csm-search-bar .search-field {
  flex:1;
  border:1px solid var(--border);
  border-right:none;
  padding:11px 16px;
  font-size:13px;
  background:#fff;
  outline:none;
}
.csm-search-bar .search-field:focus { border-color:var(--gold); }
.csm-search-bar .search-submit {
  background:var(--black);
  border:1px solid var(--black);
  color:#fff;
  padding:11px 20px;
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background var(--ease);
}
.csm-search-bar .search-submit:hover { background:var(--charcoal); }

/* ============================================
   NAVIGATION
   ============================================ */
.csm-nav-wrapper { background:var(--black); position:sticky; top:0; z-index:200; }
.csm-nav-wrapper .csm-container { display:flex; align-items:center; justify-content:center; position:relative; }
.csm-nav-menu { display:flex; align-items:center; }
.csm-nav-menu > li { position:relative; }
.csm-nav-menu > li > a {
  display:block;
  padding:15px 22px;
  font-size:10.5px;
  font-weight:500;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#bbb;
  transition:color var(--ease);
}
.csm-nav-menu > li > a:hover,
.csm-nav-menu > li.current-menu-item > a,
.csm-nav-menu > li.current-menu-parent > a { color:var(--gold); }

/* Dropdown */
.csm-nav-menu .sub-menu {
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%);
  background:var(--charcoal);
  border-top:2px solid var(--gold);
  min-width:210px;
  opacity:0;
  visibility:hidden;
  transition:opacity .2s ease, visibility .2s ease;
  z-index:300;
  box-shadow:0 8px 24px rgba(0,0,0,.25);
}
.csm-nav-menu li:hover > .sub-menu { opacity:1; visibility:visible; }
.csm-nav-menu .sub-menu li a {
  display:block;
  padding:12px 20px;
  font-size:9.5px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#999;
  border-bottom:1px solid #222;
  transition:all var(--ease);
}
.csm-nav-menu .sub-menu li:last-child a { border-bottom:none; }
.csm-nav-menu .sub-menu li a:hover { color:var(--gold); padding-left:26px; }

/* Mobile toggle */
.csm-mobile-toggle {
  display:none;
  background:none;
  border:none;
  color:#bbb;
  cursor:pointer;
  padding:15px;
  flex-direction:column;
  gap:5px;
  position:absolute;
  right:16px;
}
.csm-mobile-toggle span { width:22px; height:1px; background:currentColor; display:block; transition:all .3s; }
.csm-mobile-toggle.is-open span:nth-child(1) { transform:translateY(6px) rotate(45deg); }
.csm-mobile-toggle.is-open span:nth-child(2) { opacity:0; }
.csm-mobile-toggle.is-open span:nth-child(3) { transform:translateY(-6px) rotate(-45deg); }

/* ============================================
   TICKER / TOP STORIES
   ============================================ */
.csm-ticker {
  background:var(--parchment);
  border-bottom:1px solid var(--border);
  padding:11px 0;
  overflow:hidden;
}
.csm-ticker .csm-container { display:flex; align-items:center; gap:24px; }
.csm-ticker-label {
  font-size:9px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--rose);
  white-space:nowrap;
  padding-right:20px;
  border-right:1px solid var(--border);
  flex-shrink:0;
}
.csm-ticker-track { overflow:hidden; flex:1; }
.csm-ticker-items {
  display:flex;
  width:max-content;
  animation:csm-scroll 40s linear infinite;
}
.csm-ticker-items a {
  font-size:11.5px;
  color:var(--charcoal);
  padding:0 28px;
  white-space:nowrap;
  flex-shrink:0;
  transition:color var(--ease);
}
.csm-ticker-items a::after { content:'·'; margin-left:28px; color:var(--gold); }
.csm-ticker-items a:hover { color:var(--gold-dark); }
@keyframes csm-scroll {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}

/* ============================================
   HERO SECTION
   ============================================ */
.csm-hero { padding:52px 0; border-bottom:1px solid var(--border); }
.csm-hero-inner {
  display:grid;
  grid-template-columns:1fr 380px;
  gap:52px;
  align-items:start;
}

/* Hero main */
.csm-hero-image-wrap {
  position:relative;
  overflow:hidden;
  aspect-ratio:16/10;
  margin-bottom:28px;
  background:var(--parchment);
}
.csm-hero-image-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .65s ease; }
.csm-hero-image-wrap:hover img { transform:scale(1.03); }
.csm-hero-no-image {
  aspect-ratio:16/10;
  background:linear-gradient(135deg, var(--parchment) 0%, #D9D3CA 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:28px;
}
.csm-hero-no-image::before {
  content:'CSM';
  font-family:var(--font-display);
  font-size:80px;
  font-weight:300;
  letter-spacing:.25em;
  color:var(--border);
}
.csm-hero-category {
  display:inline-block;
  font-size:9px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-dark);
  margin-bottom:14px;
}
.csm-hero-title {
  font-family:var(--font-display);
  font-size:52px;
  font-weight:400;
  line-height:1.09;
  color:var(--black);
  margin-bottom:16px;
  letter-spacing:-.01em;
}
.csm-hero-title a:hover { color:var(--gold-dark); }
.csm-hero-excerpt { font-size:15px; color:var(--muted); line-height:1.75; margin-bottom:22px; max-width:540px; }
.csm-hero-meta {
  display:flex;
  align-items:center;
  gap:14px;
  font-size:10px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
}
.csm-meta-divider { width:1px; height:11px; background:var(--border); flex-shrink:0; }

/* Hero sidebar */
.csm-hero-sidebar { border-left:1px solid var(--border); padding-left:52px; }
.csm-sidebar-label {
  font-size:9px;
  font-weight:700;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:22px;
  padding-bottom:14px;
  border-bottom:2px solid var(--border);
}
.csm-secondary-post {
  display:grid;
  grid-template-columns:96px 1fr;
  gap:14px;
  padding:20px 0;
  border-bottom:1px solid var(--border);
  align-items:start;
}
.csm-secondary-post:last-child { border-bottom:none; padding-bottom:0; }
.csm-secondary-img { overflow:hidden; aspect-ratio:4/3; flex-shrink:0; background:var(--parchment); }
.csm-secondary-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.csm-secondary-post:hover .csm-secondary-img img { transform:scale(1.06); }
.csm-secondary-cat { font-size:8px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-dark); margin-bottom:5px; display:block; }
.csm-secondary-title { font-family:var(--font-display); font-size:18px; font-weight:500; line-height:1.25; color:var(--black); }
.csm-secondary-title a:hover { color:var(--gold-dark); }
.csm-secondary-meta { margin-top:6px; font-size:9px; letter-spacing:.07em; text-transform:uppercase; color:var(--muted); }

/* ============================================
   SECTION HEADERS
   ============================================ */
.csm-section-head {
  display:flex;
  align-items:center;
  gap:18px;
  margin-bottom:36px;
}
.csm-section-head::before {
  content:'';
  width:36px;
  height:2px;
  background:var(--gold);
  flex-shrink:0;
}
.csm-section-head::after {
  content:'';
  flex:1;
  height:1px;
  background:var(--border);
}
.csm-section-label {
  font-size:9.5px;
  font-weight:700;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--charcoal);
  white-space:nowrap;
}
.csm-section-label a { color:inherit; }
.csm-section-label a:hover { color:var(--gold-dark); }

/* ============================================
   ARTICLE CARDS
   ============================================ */
.csm-card { position:relative; display:flex; flex-direction:column; }
.csm-card-img {
  overflow:hidden;
  aspect-ratio:3/2;
  margin-bottom:18px;
  background:var(--parchment);
}
.csm-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .55s ease; }
.csm-card:hover .csm-card-img img { transform:scale(1.04); }
.csm-card-no-img {
  aspect-ratio:3/2;
  background:linear-gradient(135deg, var(--parchment), #D5CFC6);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
}
.csm-card-no-img::before {
  content:'CSM';
  font-family:var(--font-display);
  font-size:36px;
  font-weight:300;
  letter-spacing:.2em;
  color:var(--border);
}
.csm-card-cat { font-size:8.5px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-dark); margin-bottom:8px; display:block; }
.csm-card-title { font-family:var(--font-display); font-size:24px; font-weight:500; line-height:1.2; color:var(--black); margin-bottom:10px; }
.csm-card-title a:hover { color:var(--gold-dark); }
.csm-card-excerpt { font-size:13.5px; color:var(--muted); line-height:1.65; margin-bottom:14px; flex:1; }
.csm-card-meta { display:flex; align-items:center; gap:10px; font-size:9.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }

/* Small horizontal card */
.csm-card-row {
  display:grid;
  grid-template-columns:88px 1fr;
  gap:14px;
  align-items:start;
  padding-bottom:22px;
  border-bottom:1px solid var(--border);
}
.csm-card-row:last-child { border-bottom:none; padding-bottom:0; }
.csm-card-row-img { overflow:hidden; aspect-ratio:4/3; background:var(--parchment); }
.csm-card-row-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.csm-card-row:hover .csm-card-row-img img { transform:scale(1.06); }
.csm-card-row-title { font-family:var(--font-display); font-size:17px; font-weight:500; line-height:1.25; color:var(--black); margin-bottom:5px; }
.csm-card-row-title a:hover { color:var(--gold-dark); }
.csm-card-row-meta { font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }

/* ============================================
   CONTENT SECTIONS
   ============================================ */
.csm-latest { padding:60px 0; border-bottom:1px solid var(--border); }
.csm-category-section { padding:60px 0; border-bottom:1px solid var(--border); }

/* Featured in category section */
.csm-cat-featured { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.csm-cat-feat-img { overflow:hidden; aspect-ratio:4/3; background:var(--parchment); }
.csm-cat-feat-img img { width:100%; height:100%; object-fit:cover; transition:transform .55s; }
.csm-cat-featured:hover .csm-cat-feat-img img { transform:scale(1.04); }
.csm-cat-feat-content { padding-top:4px; }
.csm-cat-feat-title { font-family:var(--font-display); font-size:34px; font-weight:400; line-height:1.15; color:var(--black); margin-bottom:14px; }
.csm-cat-feat-title a:hover { color:var(--gold-dark); }
.csm-cat-feat-excerpt { font-size:14.5px; color:var(--muted); line-height:1.75; margin-bottom:20px; }
.csm-cat-feat-meta { font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.csm-cat-right { display:flex; flex-direction:column; gap:0; }

/* ============================================
   READ MORE LINK
   ============================================ */
.csm-read-more {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:9.5px;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--charcoal);
  border-bottom:1px solid var(--border);
  padding-bottom:2px;
  transition:all var(--ease);
}
.csm-read-more:hover { color:var(--gold-dark); border-color:var(--gold-dark); }
.csm-read-more::after { content:'→'; transition:transform var(--ease); }
.csm-read-more:hover::after { transform:translateX(3px); }

/* ============================================
   NEWSLETTER
   ============================================ */
.csm-newsletter { background:var(--black); padding:80px 0; text-align:center; }
.csm-newsletter-eye {
  font-size:9px;
  font-weight:700;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  display:block;
  margin-bottom:16px;
}
.csm-newsletter-title { font-family:var(--font-display); font-size:44px; font-weight:300; color:#FAFAF8; letter-spacing:.03em; margin-bottom:10px; }
.csm-newsletter-sub { font-size:14px; color:#666; margin-bottom:36px; }
.csm-newsletter-form { display:flex; justify-content:center; max-width:460px; margin:0 auto; }
.csm-newsletter-input {
  flex:1;
  padding:14px 20px;
  font-size:13px;
  background:#1A1A1A;
  border:1px solid #333;
  border-right:none;
  color:#FAFAF8;
  outline:none;
  letter-spacing:.01em;
}
.csm-newsletter-input::placeholder { color:#555; }
.csm-newsletter-input:focus { border-color:var(--gold); }
.csm-newsletter-btn {
  padding:14px 28px;
  background:var(--gold);
  border:1px solid var(--gold);
  font-size:9.5px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--black);
  cursor:pointer;
  transition:all var(--ease);
}
.csm-newsletter-btn:hover { background:var(--gold-dark); border-color:var(--gold-dark); }

/* ============================================
   FOOTER
   ============================================ */
.csm-footer { background:#1A1A1A; color:#888; padding:64px 0 0; }
.csm-footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.csm-footer-logo-text { font-family:var(--font-display); font-size:20px; font-weight:300; letter-spacing:.2em; text-transform:uppercase; color:#FAFAF8; display:block; margin-bottom:4px; }
.csm-footer-rule { width:32px; height:1px; background:var(--gold); margin:10px 0; }
.csm-footer-tagline { font-family:var(--font-display); font-style:italic; font-size:13px; color:#555; margin-bottom:18px; display:block; }
.csm-footer-desc { font-size:12px; line-height:1.85; color:#555; }
.csm-footer-col-title { font-size:9px; font-weight:700; letter-spacing:.24em; text-transform:uppercase; color:#FAFAF8; margin-bottom:20px; padding-bottom:12px; border-bottom:1px solid #2E2E2E; }
.csm-footer-links li { margin-bottom:10px; }
.csm-footer-links a { font-size:12px; color:#666; letter-spacing:.01em; }
.csm-footer-links a:hover { color:var(--gold); }
.csm-footer-recent { display:flex; gap:12px; margin-bottom:16px; align-items:flex-start; }
.csm-footer-recent-img { width:52px; height:38px; object-fit:cover; flex-shrink:0; }
.csm-footer-recent-title { font-family:var(--font-display); font-size:14px; color:#888; line-height:1.3; }
.csm-footer-recent-title:hover { color:var(--gold); }
.csm-footer-contact-block { margin-bottom:16px; }
.csm-footer-contact-lbl { font-size:8px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:3px; display:block; }
.csm-footer-contact-val { font-size:12px; color:#666; }
.csm-footer-contact-val a { color:#666; }
.csm-footer-contact-val a:hover { color:var(--gold); }
.csm-footer-bottom { border-top:1px solid #262626; padding:20px 0; display:flex; align-items:center; justify-content:space-between; }
.csm-footer-copy { font-size:10.5px; color:#444; letter-spacing:.06em; }
.csm-footer-legal { display:flex; gap:24px; }
.csm-footer-legal a { font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:#444; }
.csm-footer-legal a:hover { color:var(--gold); }

/* ============================================
   SINGLE POST
   ============================================ */
.csm-single { padding-bottom:80px; }
.csm-single-hero-img { width:100%; aspect-ratio:21/8; object-fit:cover; display:block; }
.csm-single-header { max-width:760px; margin:52px auto 40px; text-align:center; padding:0 40px; }
.csm-single-cat { font-size:9px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-dark); display:block; margin-bottom:18px; }
.csm-single-title { font-family:var(--font-display); font-size:54px; font-weight:400; line-height:1.08; color:var(--black); margin-bottom:22px; letter-spacing:-.01em; }
.csm-single-meta { display:flex; align-items:center; justify-content:center; gap:16px; font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.csm-single-rule { width:48px; height:2px; background:var(--gold); margin:28px auto 0; }
.csm-single-layout { display:grid; grid-template-columns:1fr 300px; gap:64px; max-width:var(--max-width); margin:48px auto 0; padding:0 40px; }
.csm-single-content { font-size:17px; line-height:1.85; color:var(--charcoal); }
.csm-single-content p { margin-bottom:1.5em; }
.csm-single-content h2 { font-family:var(--font-display); font-size:32px; font-weight:500; color:var(--black); margin:2em 0 .7em; line-height:1.2; }
.csm-single-content h3 { font-family:var(--font-display); font-size:24px; font-weight:500; color:var(--black); margin:1.8em 0 .6em; }
.csm-single-content blockquote {
  border-left:3px solid var(--gold);
  padding:20px 32px;
  margin:2em 0;
  background:var(--parchment);
  font-family:var(--font-display);
  font-style:italic;
  font-size:24px;
  line-height:1.5;
  color:var(--charcoal);
}
.csm-single-content img { width:100%; margin:2em 0; }
.csm-single-content ul, .csm-single-content ol { padding-left:1.4em; margin-bottom:1.5em; }
.csm-single-content ul { list-style:disc; }
.csm-single-content ol { list-style:decimal; }
.csm-single-content li { margin-bottom:.5em; }
.csm-single-content a { color:var(--gold-dark); border-bottom:1px solid var(--border); }
.csm-single-content a:hover { border-color:var(--gold-dark); }
.csm-single-content figure { margin:2em 0; }
.csm-single-content figcaption { font-size:12px; color:var(--muted); text-align:center; margin-top:8px; letter-spacing:.03em; }

/* Author box */
.csm-author-box { display:flex; gap:20px; align-items:flex-start; padding:28px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-top:48px; }
.csm-author-avatar { width:64px; height:64px; border-radius:50%; object-fit:cover; flex-shrink:0; background:var(--parchment); }
.csm-author-name { font-family:var(--font-display); font-size:18px; font-weight:600; margin-bottom:4px; }
.csm-author-bio { font-size:13px; color:var(--muted); line-height:1.65; }

/* Related posts */
.csm-related { padding:60px 0 0; }
.csm-related-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:32px; }

/* ============================================
   SIDEBAR
   ============================================ */
.csm-sidebar { padding-top:4px; }
.csm-sidebar-widget { margin-bottom:40px; }
.csm-sidebar-widget-title {
  font-size:9px;
  font-weight:700;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--charcoal);
  margin-bottom:18px;
  padding-bottom:12px;
  border-bottom:2px solid var(--border);
  display:flex;
  align-items:center;
  gap:10px;
}
.csm-sidebar-widget-title::before { content:''; width:18px; height:2px; background:var(--gold); flex-shrink:0; }

/* ============================================
   ARCHIVE
   ============================================ */
.csm-archive { padding:60px 0; }
.csm-archive-header { text-align:center; padding-bottom:40px; margin-bottom:40px; border-bottom:1px solid var(--border); }
.csm-archive-eye { font-size:9px; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); display:block; margin-bottom:8px; }
.csm-archive-title { font-family:var(--font-display); font-size:46px; font-weight:300; letter-spacing:.04em; color:var(--black); }
.csm-archive-layout { display:grid; grid-template-columns:1fr 300px; gap:60px; }
.csm-archive-grid { display:grid; grid-template-columns:1fr 1fr; gap:36px; align-content:start; }

/* ============================================
   PAGINATION
   ============================================ */
.csm-pagination { display:flex; justify-content:center; gap:6px; margin-top:52px; padding-top:32px; border-top:1px solid var(--border); }
.csm-pagination .page-numbers {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  font-size:12px;
  border:1px solid var(--border);
  color:var(--muted);
  transition:all var(--ease);
}
.csm-pagination a.page-numbers:hover,
.csm-pagination .page-numbers.current { background:var(--black); border-color:var(--black); color:var(--ivory); }

/* ============================================
   UTILS / BUTTONS
   ============================================ */
.csm-btn {
  display:inline-block;
  padding:13px 32px;
  border:1px solid var(--black);
  font-size:10px;
  font-weight:600;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--black);
  transition:all var(--ease);
}
.csm-btn:hover { background:var(--black); color:var(--ivory); }
.csm-btn-gold { background:var(--gold); border-color:var(--gold); color:var(--black); }
.csm-btn-gold:hover { background:var(--gold-dark); border-color:var(--gold-dark); color:var(--black); }

/* 404 */
.csm-404 { text-align:center; padding:120px 40px; }
.csm-404-number { font-family:var(--font-display); font-size:160px; font-weight:300; color:var(--parchment); line-height:1; letter-spacing:.1em; margin-bottom:16px; }
.csm-404-title { font-family:var(--font-display); font-size:32px; font-weight:400; color:var(--black); margin-bottom:12px; }
.csm-404-text { font-size:15px; color:var(--muted); margin-bottom:32px; }

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width:1100px) {
  .csm-container { padding:0 24px; }
  .csm-hero-inner { grid-template-columns:1fr 340px; gap:36px; }
  .csm-hero-sidebar { padding-left:36px; }
  .csm-footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .csm-single-layout { gap:40px; }
  .csm-single-title { font-size:44px; }
}
@media (max-width:900px) {
  .csm-hero-inner { grid-template-columns:1fr; }
  .csm-hero-sidebar { border-left:none; padding-left:0; border-top:1px solid var(--border); padding-top:32px; }
  .csm-hero-sidebar-posts { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
  .csm-secondary-post { grid-template-columns:1fr; border-bottom:none; padding:0; }
  .csm-secondary-img { aspect-ratio:16/9; }
  .csm-cat-featured { grid-template-columns:1fr; }
  .csm-single-layout { grid-template-columns:1fr; }
  .csm-archive-layout { grid-template-columns:1fr; }
  .csm-related-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
  .csm-topbar { display:none; }
  .csm-masthead { padding:20px 0; }
  .csm-masthead .csm-container { flex-direction:column; gap:4px; }
  .csm-masthead-side, .csm-masthead-search { display:none; }
  .csm-logo-text { font-size:22px; letter-spacing:.14em; }
  .csm-mobile-toggle { display:flex; }
  .csm-nav-menu {
    display:none;
    position:absolute;
    top:100%;
    left:0; right:0;
    background:var(--black);
    flex-direction:column;
    border-top:1px solid #1A1A1A;
    box-shadow:0 8px 20px rgba(0,0,0,.3);
  }
  .csm-nav-menu.is-active { display:flex; }
  .csm-nav-menu > li > a { padding:13px 20px; border-bottom:1px solid #1A1A1A; }
  .csm-nav-menu .sub-menu {
    position:static; transform:none;
    opacity:1; visibility:visible;
    display:none;
    box-shadow:none;
    border:none; border-top:1px solid #1A1A1A;
    background:#0A0A0A;
    width:100%;
  }
  .csm-nav-menu li.is-open > .sub-menu { display:block; }
  .csm-grid-3 { grid-template-columns:1fr; }
  .csm-grid-2 { grid-template-columns:1fr; }
  .csm-hero-title { font-size:34px; }
  .csm-single-title { font-size:32px; }
  .csm-archive-title { font-size:32px; }
  .csm-newsletter-title { font-size:30px; }
  .csm-newsletter-form { flex-direction:column; }
  .csm-newsletter-input { border-right:1px solid #333; border-bottom:none; }
  .csm-footer-grid { grid-template-columns:1fr; gap:28px; }
  .csm-footer-bottom { flex-direction:column; gap:12px; text-align:center; }
  .csm-archive-grid { grid-template-columns:1fr; }
  .csm-related-grid { grid-template-columns:1fr; }
  .csm-404-number { font-size:100px; }
  .csm-ticker { display:none; }
  .csm-hero-sidebar-posts { grid-template-columns:1fr; }
}
@media (prefers-reduced-motion:reduce) {
  .csm-ticker-items { animation:none; }
  * { transition-duration:.01ms !important; }
}
