@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap');

/* ========== RESET & BASE ========== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --primary: #c0392b;
  --primary-dark: #96281b;
  --primary-light: #e74c3c;
  --dark: #1a1a1a;
  --dark2: #111111;
  --text: #222222;
  --text-muted: #5a5a5a;
  --text-light: #8a8a8a;
  --bg: #f0f0f0;
  --bg2: #ffffff;
  --bg3: #fafafa;
  --border: #e2e2e2;
  --border-light: #ececec;
  --radius: 6px;
  --radius-lg: 10px;
  --shadow-sm: 0 1px 4px rgba(0,0,0,.06);
  --shadow: 0 2px 10px rgba(0,0,0,.08);
  --shadow-md: 0 6px 24px rgba(0,0,0,.11);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.14);
  --font-serif: Georgia, 'Times New Roman', serif;
  --font-sans: Verdana, Geneva, Tahoma, sans-serif;
  --container: 1300px;
  --transition: .2s ease;
  --sticky-header-offset: 80px;
}
body {
  font-family: var(--font-sans);
  color: var(--text);
  background: var(--bg);
  line-height: 1.65;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
.container { max-width: var(--container); margin: 0 auto; padding: 0 1.5rem; }

/* ========== HEADER ========== */
.site-header {
  background: var(--bg2);
  position: sticky;
  top: 0;
  z-index: 200;
  box-shadow: 0 2px 12px rgba(0,0,0,.08);
}
.header-top {
  background: var(--dark2);
  color: rgba(255,255,255,.72);
  font-size: .7rem;
  padding: .32rem 0;
  letter-spacing: .02em;
}
.header-top-inner { display: flex; justify-content: space-between; align-items: center; }
.header-date { font-size: .68rem; text-transform: uppercase; letter-spacing: .06em; opacity: .8; }
.header-social { display: flex; gap: .3rem; }
.social-link {
  color: rgba(255,255,255,.55);
  padding: .15rem .55rem;
  font-size: .68rem;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 3px;
  transition: all var(--transition);
  letter-spacing: .02em;
}
.social-link:hover { color: #fff; border-color: rgba(255,255,255,.35); background: rgba(255,255,255,.08); }
.header-main { padding: .9rem 0 .8rem; border-bottom: 1px solid var(--border); background: #fff; }
.header-main-inner { display: flex; align-items: center; gap: 1.5rem; }
.site-logo { display: flex; align-items: center; text-decoration: none; flex-shrink: 0; }
.logo-icon { display: none; }
.logo-text {
  font-family: var(--font-serif);
  font-size: 1.95rem;
  font-weight: 700;
  font-style: italic;
  color: var(--dark);
  letter-spacing: -.035em;
  line-height: 1;
}
.header-search {
  flex: 1;
  max-width: 400px;
  display: flex;
  border: 1.5px solid var(--border);
  border-radius: 24px;
  overflow: hidden;
  background: var(--bg3);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.header-search:focus-within { border-color: var(--text); box-shadow: 0 0 0 3px rgba(192,57,43,.1); }
.search-input {
  flex: 1;
  padding: .5rem 1rem;
  border: none;
  font-size: .8rem;
  font-family: var(--font-sans);
  outline: none;
  background: transparent;
  color: var(--text);
}
.search-input::placeholder { color: #bbb; }
.search-btn {
  padding: .5rem .85rem;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
  transition: color var(--transition);
  display: flex;
  align-items: center;
}
.search-btn:hover { color: var(--text); }
.btn-admin {
  background: var(--dark);
  color: #fff;
  padding: .42rem 1rem;
  border-radius: 5px;
  font-size: .75rem;
  font-family: var(--font-sans);
  font-weight: 600;
  white-space: nowrap;
  transition: background var(--transition);
}
.btn-admin:hover { background: var(--primary); }

/* Navigation */
.main-nav { background: var(--bg2); border-bottom: 3px solid var(--primary); }
.nav-list { list-style: none; display: flex; flex-wrap: wrap; }
.nav-link {
  display: block;
  padding: .58rem 1rem;
  color: var(--dark);
  font-size: .68rem;
  font-family: var(--font-sans);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  transition: color var(--transition);
  position: relative;
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--cat-color, var(--primary));
  opacity: 0;
  transition: opacity var(--transition);
}
.nav-link:hover { color: var(--text); }
.nav-link:hover::after { opacity: 1; }
.mobile-menu-btn { display: none; background: none; border: none; color: var(--dark); font-size: 1.3rem; padding: .4rem; cursor: pointer; }

/* ========== HERO SECTION ========== */
.hero-section {
  padding: 1.5rem 0;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
}
.hero-grid { display: grid; grid-template-columns: 3fr 1.45fr; gap: 1.5rem; }
.hero-main-link { display: block; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); transition: box-shadow var(--transition); }
.hero-main-link:hover { box-shadow: var(--shadow-md); }
.hero-image-wrap { position: relative; aspect-ratio: 16/9; background: #ddd; overflow: hidden; }
.hero-image { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.hero-main-link:hover .hero-image { transform: scale(1.025); }
.hero-image-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--dark) 0%, #444 100%); }
.hero-overlay { display: none; }
.hero-content { padding: 1.1rem 1.2rem 1.2rem; background: #fff; }
.hero-category { display: inline-block; font-size: .66rem; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: .09em; color: var(--text); margin-bottom: .45rem; }
.hero-title { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: 1.58rem; line-height: 1.3; font-weight: 700; color: var(--dark); margin-bottom: .55rem; transition: color var(--transition); }
.hero-main-link:hover .hero-title { color: var(--text); }
.hero-excerpt { font-size: .83rem; font-family: var(--font-sans); color: var(--text-muted); line-height: 1.6; margin-bottom: .65rem; }
.hero-meta { font-size: .7rem; color: var(--text-light); display: flex; gap: .75rem; flex-wrap: wrap; font-family: var(--font-sans); }

.hero-sidebar { display: flex; flex-direction: column; gap: .8rem; }
.hero-side-item {
  display: flex;
  gap: 0;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  background: #fff;
  transition: box-shadow var(--transition), transform var(--transition);
}
.hero-side-item:hover { box-shadow: var(--shadow); transform: translateY(-1px); }
.side-item-image { width: 90px; flex-shrink: 0; aspect-ratio: 4/3; overflow: hidden; background: #ddd; }
.side-item-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.hero-side-item:hover .side-item-image img { transform: scale(1.07); }
.side-item-placeholder { width: 100%; height: 100%; background: #ccc; }
.side-item-content { padding: .8rem .85rem .8rem .75rem; display: flex; flex-direction: column; gap: .28rem; flex: 1; }
.side-item-cat { font-size: .62rem; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--text); }
.side-item-title { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: .82rem; font-weight: 700; line-height: 1.42; color: var(--text); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.hero-side-item:hover .side-item-title { color: var(--text); }
.side-item-date { font-size: .67rem; color: var(--text-light); margin-top: auto; font-family: var(--font-sans); }

/* ========== SECTIONS ========== */
.section { padding: 2rem 0; background: var(--bg2); }
.section:nth-child(odd) { background: var(--bg3); }
.latest-section { background: var(--bg2) !important; }
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.35rem;
  padding-bottom: .6rem;
  border-bottom: 2.5px solid var(--primary);
  gap: 1rem;
}
.section-title { font-family: var(--font-sans); font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--text); }
.section-line { display: none; }
.section-more { font-size: .68rem; color: var(--text-muted); font-weight: 600; text-transform: uppercase; letter-spacing: .07em; transition: color var(--transition); white-space: nowrap; font-family: var(--font-sans); }
.section-more:hover { color: var(--text); }
.cat-section-link { color: var(--text); }
.cat-section-link:hover { text-decoration: none; }

/* ========== ARTICLES GRID ========== */
.articles-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.articles-grid-4 { grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.article-card {
  background: var(--bg2);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--transition), transform var(--transition);
  border: 1px solid var(--border-light);
}
.article-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.card-image-link { display: block; aspect-ratio: 16/9; overflow: hidden; background: #e5e5e5; flex-shrink: 0; }
.card-image { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.article-card:hover .card-image { transform: scale(1.04); }
.card-no-image { display: flex; align-items: center; justify-content: center; font-size: 2rem; opacity: .18; }
.card-body { padding: .9rem 1rem 1rem; flex: 1; display: flex; flex-direction: column; gap: .38rem; }
.card-category { display: inline-block; font-size: .62rem; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: .09em; color: var(--text); }
.card-title { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: .9rem; font-weight: 700; line-height: 1.42; flex: 1; }
.card-title a { color: var(--text); transition: color var(--transition); }
.card-title a:hover { color: var(--text); }
.card-title-sm { font-size: .88rem; }
.card-excerpt { font-size: .78rem; font-family: var(--font-sans); color: var(--text-muted); line-height: 1.55; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-meta { display: flex; gap: .55rem; flex-wrap: wrap; font-size: .68rem; font-family: var(--font-sans); color: var(--text-light); margin-top: auto; padding-top: .5rem; border-top: 1px solid var(--border-light); }
.article-card-sm .card-title { font-size: .86rem; }

/* ========== CATEGORY HERO ========== */
.category-hero { background: transparent; padding: 1.1rem 0; border: 0; }
.cat-badge { display: inline-block; background: var(--m3-primary-container); color: var(--m3-primary); padding: .22rem .8rem; border-radius: 3px; font-size: .68rem; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: .09em; margin-bottom: .6rem; }
.cat-page-title { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: 1.8rem; font-weight: 700; color: var(--dark); }
.cat-page-desc { color: var(--text-muted); margin-top: .4rem; font-size: .88rem; font-family: var(--font-sans); }
.cat-count { color: var(--text-light); font-size: .75rem; margin-top: .35rem; font-family: var(--font-sans); }

/* ========== STATIC PAGE ========== */
.static-page-main { padding: 1.2rem 0 3rem; background: transparent; }
.static-page-hero-shell {
  background: var(--m3-surface-container-low);
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-lg);
  padding: 1.1rem 1.2rem;
  margin-bottom: 1rem;
}
.static-page-title {
  font-family: var(--font-serif);
  font-size: clamp(1.35rem, 2.35vw, 2.1rem);
  line-height: 1.24;
  color: var(--m3-on-surface);
}
.static-page-excerpt {
  margin-top: .55rem;
  color: var(--m3-on-surface-variant);
  font-size: .95rem;
  max-width: 78ch;
}
.static-page-meta {
  margin-top: .65rem;
  display: flex;
  flex-wrap: wrap;
  gap: .55rem 1rem;
  color: color-mix(in srgb, var(--m3-on-surface-variant) 90%, transparent);
  font-size: .78rem;
}
.static-page-card {
  background: #fff;
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-lg);
  box-shadow: var(--m3-shadow-1);
  padding: clamp(1rem, 2vw, 1.5rem);
}
.static-page-content {
  max-width: 84ch;
}

/* ========== CONTACT PAGE ========== */
.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: 1rem;
}
.contact-info-card,
.contact-form-card {
  height: 100%;
}
.contact-section-title {
  font-size: 1.15rem;
  margin-bottom: .8rem;
  color: var(--m3-on-surface);
}
.contact-subtitle {
  font-size: .92rem;
  margin: 1rem 0 .45rem;
  color: var(--m3-on-surface);
}
.contact-lines p,
.contact-note {
  font-size: .9rem;
  color: var(--m3-on-surface-variant);
  line-height: 1.52;
  margin-bottom: .28rem;
}
.contact-note {
  margin-top: .9rem;
  padding: .65rem .75rem;
  border: 1px solid var(--m3-outline-variant);
  border-radius: 10px;
  background: var(--m3-surface-container);
}
.contact-list {
  list-style: none;
  display: grid;
  gap: .35rem;
  margin: .25rem 0 .1rem;
}
.contact-list li,
.contact-info-card p {
  font-size: .9rem;
  color: var(--m3-on-surface-variant);
}
.contact-info-card a {
  color: var(--m3-primary);
  text-decoration: none;
  text-underline-offset: 2px;
}
.contact-form {
  display: grid;
  gap: .78rem;
  min-width: 0;
}
.contact-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .78rem;
  min-width: 0;
}
.contact-form-row > * {
  min-width: 0;
}
.contact-form-card .form-label {
  margin-bottom: .3rem;
}
.contact-form-card .form-group {
  min-width: 0;
}
.contact-form-card .form-input,
.contact-form-card .form-textarea {
  width: 100%;
  min-width: 0;
  max-width: 100%;
}
.contact-form-card {
  overflow: hidden;
}
.contact-submit-btn {
  width: 100%;
}

/* ========== ALL PAGES LIST ========== */
.all-pages-list-wrap {
  padding: 1rem;
}
.all-pages-list {
  list-style: none;
  display: grid;
  gap: .65rem;
}
.all-pages-item {
  border: 1px solid var(--m3-outline-variant);
  border-radius: 12px;
  background: var(--m3-surface-container-low);
}
.all-pages-item-static {
  border-color: color-mix(in srgb, var(--m3-primary) 45%, var(--m3-outline-variant));
  background: color-mix(in srgb, var(--m3-primary-container) 30%, #fff);
}
.all-pages-link {
  display: block;
  padding: .8rem .9rem;
}
.all-pages-link-title {
  display: block;
  font-size: .96rem;
  font-weight: 700;
  color: var(--m3-on-surface);
}
.all-pages-link-desc {
  display: block;
  margin-top: .18rem;
  font-size: .84rem;
  color: var(--m3-on-surface-variant);
}
.all-pages-empty {
  display: block;
  padding: .8rem .9rem;
  font-size: .88rem;
  color: var(--m3-on-surface-variant);
}
@media (max-width: 980px) {
  .contact-grid,
  .contact-form-row {
    grid-template-columns: 1fr;
  }
}

/* ========== SEARCH ========== */
.search-hero { background: var(--dark); color: #fff; padding: 2.5rem 0; }
.search-page-title { font-family: var(--font-serif); font-size: 1.75rem; margin-bottom: 1.25rem; font-weight: 700; }
.search-page-form { display: flex; max-width: 540px; border-radius: 6px; overflow: hidden; }
.search-page-input { flex: 1; padding: .75rem 1rem; font-size: .9rem; font-family: var(--font-sans); border: none; background: rgba(255,255,255,.12); outline: none; color: #fff; }
.search-page-input::placeholder { color: rgba(255,255,255,.4); }
.search-page-btn { padding: .75rem 1.5rem; background: var(--primary); color: #fff; border: none; font-size: .8rem; font-family: var(--font-sans); font-weight: 700; cursor: pointer; transition: background var(--transition); text-transform: uppercase; letter-spacing: .05em; }
.search-page-btn:hover { background: var(--primary-dark); }
.search-result-count { margin-top: .85rem; font-size: .82rem; opacity: .7; font-family: var(--font-sans); }

/* ========== ARTICLE PAGE ========== */
.article-main { padding: 1.75rem 0 3rem; background: var(--bg2); }
.article-layout { display: grid; grid-template-columns: minmax(0, 1fr) 290px; gap: 0 2.5rem; align-items: start; }
.article-col-wrap { min-width: 0; }
.article-body { min-width: 0; }
.breadcrumb { display: flex; align-items: center; gap: .4rem; font-size: .7rem; font-family: var(--font-sans); color: var(--text-light); margin-bottom: 1.1rem; flex-wrap: wrap; }
.breadcrumb a { color: var(--text); }
.breadcrumb a:hover { text-decoration: none; }
.breadcrumb-current { color: var(--text-light); }
.article-category { display: inline-block; font-size: .68rem; font-family: var(--font-sans); font-weight: 700; color: var(--text); text-transform: uppercase; letter-spacing: .09em; margin-bottom: .7rem; }
.article-title { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: 2.1rem; line-height: 1.26; font-weight: 700; color: var(--dark); margin-bottom: .8rem; }
.article-lead { font-size: 1rem; font-family: Verdana, Geneva, Tahoma, sans-serif; color: var(--text-muted); line-height: 1.7; margin-bottom: 1.25rem; font-weight: 400; border-left: 3px solid var(--primary); padding-left: 1.1rem; background: linear-gradient(to right, rgba(192,57,43,.04), transparent 80%); border-radius: 0 4px 4px 0; padding-top: .3rem; padding-bottom: .3rem; }
.article-meta { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; font-size: .75rem; font-family: var(--font-sans); color: var(--text-light); padding: .7rem 0; border-top: 1px solid var(--border); border-bottom: 0; margin-bottom: .4rem; }
.meta-item { display: flex; align-items: center; gap: .3rem; }
.meta-author { font-weight: 700; color: var(--text-muted); }
.meta-edit { color: var(--text); font-weight: 600; }
.meta-edit:hover { text-decoration: none; }
.meta-dot { color: var(--border); }
.meta-edit-link { color: var(--text); font-weight: 600; font-size: .73rem; font-family: var(--font-sans); }
.meta-edit-link:hover { text-decoration: none; }
.article-meta-updated { font-size: .7rem; font-family: var(--font-sans); color: var(--text-light); display: flex; align-items: center; gap: .35rem; padding: 0 0 .5rem; border-bottom: 0; margin-bottom: .7rem; }
.article-image-wrap { margin: 1.2rem 0 1.4rem; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.article-image { width: 100%; max-height: 500px; object-fit: cover; }

/* ===== READING TOOLBAR ===== */
.reading-toolbar {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .55rem 0;
  margin-bottom: .9rem;
  border-bottom: 1px solid var(--border-light);
  flex-wrap: wrap;
}
.read-tool-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .25rem;
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text-muted);
  padding: .32rem .72rem;
  border-radius: 5px;
  font-size: .75rem;
  font-family: var(--font-sans);
  font-weight: 700;
  cursor: pointer;
  transition: all var(--transition);
  min-width: 36px;
  line-height: 1;
}
.read-tool-btn:hover { background: var(--dark); border-color: var(--dark); color: #fff; }
.read-tool-btn.active { background: var(--primary); border-color: var(--text); color: #fff; }

/* Article content typography */
.article-content { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: .97rem; line-height: 1.85; color: var(--text); }
.article-content h1,.article-content h2,.article-content h3,.article-content h4,.article-content h5 { font-family: Verdana, Geneva, Tahoma, sans-serif; margin: 1.8rem 0 .8rem; color: var(--dark); font-weight: 700; }
.article-content h2 { font-size: 1.3rem; }
.article-content h3 { font-size: 1.1rem; }
.article-content h4 { font-size: 1rem; }
.article-content p { margin-bottom: 1.2rem; }
.article-content ul,.article-content ol { margin: .85rem 0 1.2rem 1.65rem; }
.article-content li { margin-bottom: .4rem; }
.article-content hr { display: none !important; }
.article-content blockquote { border-left: 3px solid var(--primary); padding: .85rem 1.2rem; background: linear-gradient(to right, rgba(192,57,43,.05), transparent 80%); margin: 1.5rem 0; font-style: italic; color: var(--text-muted); font-size: 1rem; border-radius: 0 var(--radius) var(--radius) 0; }
.article-content a { color: var(--text); text-decoration: underline; }
.article-content img { max-width: 100%; height: auto; margin: 1rem 0; border-radius: var(--radius); }
.article-content code { background: var(--bg); padding: .15rem .4rem; font-size: .87em; font-family: 'Courier New', monospace; border: 1px solid var(--border); border-radius: 3px; }
.article-content pre { background: var(--dark); color: #e8e8e8; padding: 1.2rem; border-radius: var(--radius); overflow-x: auto; margin: 1.25rem 0; font-size: .85rem; }
.article-content table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: .9rem; }
.article-content table th, .article-content table td { padding: .6rem .85rem; border: 1px solid var(--border); text-align: left; vertical-align: top; }
.article-content table th { background: var(--bg3); font-weight: 700; font-family: var(--font-sans); font-size: .78rem; text-transform: uppercase; letter-spacing: .05em; }
.article-content table tr:nth-child(even) { background: var(--bg3); }
.article-content .content-table-scroll {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable both-edges;
  margin: 1.5rem 0;
  border: 1px solid var(--m3-outline-variant);
  border-radius: 12px;
  background: var(--m3-surface);
}
.article-content .content-table-scroll > table {
  width: max-content;
  min-width: 100%;
  margin: 0;
}
.article-content .content-table-scroll > table th {
  white-space: nowrap;
}
@media (max-width: 900px) {
  .article-content .content-table-scroll {
    margin: 1.15rem 0;
    border-radius: 10px;
  }

  .article-content .content-table-scroll > table th,
  .article-content .content-table-scroll > table td {
    padding: .55rem .65rem;
    font-size: .82rem;
  }
}
.article-content ul, .article-content ol { padding-left: 1.5rem; margin: .85rem 0; }
.video-embed-wrap { position: relative; width: 100%; padding-top: 56.25%; margin: 1.5rem 0; overflow: hidden; background: #000; border-radius: var(--radius); }
.video-embed-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* Tags & Share */
.article-tags { display: flex; align-items: center; gap: .4rem; flex-wrap: wrap; margin: 1.75rem 0 1rem; padding-top: 1.1rem; border-top: 1px solid var(--border); }
.tags-label { font-size: .72rem; font-family: var(--font-sans); color: var(--text-light); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.tag-item { background: var(--bg3); border: 1px solid var(--border); padding: .22rem .7rem; border-radius: 20px; font-size: .72rem; font-family: var(--font-sans); color: var(--text-muted); transition: all var(--transition); }
.tag-item:hover { border-color: var(--text); color: var(--primary); background: rgba(192,57,43,.05); }
.article-sources-section { margin: .2rem 0 1.25rem; }
.article-sources-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  background: var(--bg3);
  color: var(--text);
  font-size: .8rem;
  font-family: var(--font-sans);
  font-weight: 700;
  border-radius: 999px;
  padding: .5rem .95rem;
  cursor: pointer;
  transition: all var(--transition);
}
.article-sources-trigger:hover { border-color: var(--text); color: var(--primary); }

.sources-modal {
  position: fixed;
  inset: 0;
  z-index: 420;
  display: none;
}
.sources-modal.open { display: block; }
.sources-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .56);
}
.sources-modal-dialog {
  position: relative;
  width: min(760px, calc(100vw - 2rem));
  max-height: calc(100vh - 3rem);
  overflow: hidden;
  margin: 1.5rem auto;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
}
.sources-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .95rem 1.1rem;
  border-bottom: 1px solid var(--border);
}
.sources-modal-head h2 {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--dark);
}
.sources-modal-close {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--bg3);
  cursor: pointer;
  color: var(--text);
  font-size: .95rem;
}
.sources-modal-body {
  overflow-y: auto;
  padding: .9rem 1rem 1rem;
}
.sources-modal-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .6rem;
}
.sources-modal-item {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg3);
  padding: .7rem .8rem;
  display: flex;
  align-items: flex-start;
  gap: .7rem;
  justify-content: space-between;
}
.sources-modal-url-wrap { display: flex; gap: .5rem; min-width: 0; }
.sources-modal-index { font-size: .76rem; font-weight: 700; color: var(--text-light); margin-top: .1rem; }
.sources-modal-link {
  color: var(--text);
  text-decoration: none;
  text-underline-offset: 2px;
  word-break: break-word;
  font-size: .84rem;
}
.source-copy-btn {
  border: 1px solid var(--border);
  background: #fff;
  color: var(--text);
  border-radius: 999px;
  padding: .4rem .8rem;
  font-size: .75rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
}
.source-copy-btn:hover { border-color: var(--text); color: var(--primary); }
.source-copy-btn.copied { border-color: #16a34a; color: #166534; }
body.sources-modal-open { overflow: hidden; }
.article-share { display: flex; align-items: center; gap: .5rem; margin: 1rem 0 2rem; }
.share-label { font-size: .72rem; font-family: var(--font-sans); color: var(--text-light); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.share-btn { padding: .35rem .9rem; border-radius: 5px; font-size: .72rem; font-family: var(--font-sans); font-weight: 700; color: #fff; transition: opacity var(--transition); }
.share-btn:hover { opacity: .85; }
.share-fb { background: #1877f2; }
.share-tw { background: #111; }

/* Comments */
.comments-section { margin-top: 2.5rem; padding-top: 1.5rem; border-top: 2.5px solid var(--primary); }
.comments-title { font-family: var(--font-sans); font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--text); margin-bottom: 1.5rem; }
.comments-list { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 2rem; }
.comment { display: flex; gap: .85rem; padding-bottom: 1rem; border-bottom: 1px solid var(--border-light); }
.comment:last-child { border-bottom: none; }
.comment-avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--dark); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .8rem; flex-shrink: 0; font-family: var(--font-sans); }
.comment-body { flex: 1; }
.comment-header { display: flex; align-items: center; gap: .75rem; margin-bottom: .4rem; }
.comment-author { font-weight: 700; font-size: .85rem; font-family: var(--font-sans); }
.comment-date { font-size: .7rem; color: var(--text-light); font-family: var(--font-sans); }
.comment-text { font-size: .85rem; font-family: var(--font-sans); line-height: 1.65; color: var(--text-muted); }
.no-comments { color: var(--text-light); font-style: italic; margin-bottom: 1.5rem; font-size: .85rem; font-family: var(--font-sans); }
.comment-form-wrap { background: var(--bg3); padding: 1.5rem; border-radius: var(--radius-lg); border: 1px solid var(--border); }
.comment-form-title { font-size: .72rem; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--text-muted); margin-bottom: 1.25rem; }
.comment-form { display: flex; flex-direction: column; gap: 1rem; }
.comment-auth-note { margin: 0; font-size: .82rem; color: var(--m3-on-surface-variant); }
.comment-auth-note strong { color: var(--m3-on-surface); font-weight: 700; }
.comment-honeypot-field { position: absolute !important; left: -10000px !important; top: auto !important; width: 1px !important; height: 1px !important; overflow: hidden !important; opacity: 0 !important; pointer-events: none !important; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { display: flex; flex-direction: column; gap: .35rem; }
.form-group label { font-size: .72rem; font-family: var(--font-sans); font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: .05em; }
.form-input { padding: .55rem .85rem; border: 1.5px solid var(--border); border-radius: var(--radius); font-size: .85rem; font-family: var(--font-sans); outline: none; transition: border-color var(--transition), box-shadow var(--transition); background: var(--bg2); color: var(--text); }
.form-input:focus { border-color: var(--text); box-shadow: 0 0 0 3px rgba(192,57,43,.1); }
.form-textarea { padding: .6rem .85rem; border: 1.5px solid var(--border); border-radius: var(--radius); font-size: .85rem; font-family: var(--font-sans); outline: none; resize: vertical; transition: border-color var(--transition), box-shadow var(--transition); }
.form-textarea:focus { border-color: var(--text); box-shadow: 0 0 0 3px rgba(192,57,43,.1); }
.btn-submit { background: var(--primary); color: #fff; padding: .62rem 1.5rem; border: none; border-radius: var(--radius); font-size: .78rem; font-family: var(--font-sans); font-weight: 700; cursor: pointer; align-self: flex-start; transition: background var(--transition); text-transform: uppercase; letter-spacing: .06em; }
.btn-submit:hover { background: var(--primary-dark); }

/* ===== STICKY SOCIAL SIDEBAR ===== */
.article-content-row {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  gap: 0 1rem;
  align-items: start;
}
.article-text-area { min-width: 0; max-width: 100%; }
.social-sidebar {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .35rem;
  position: sticky;
  top: var(--sticky-header-offset);
  align-self: start;
}
.social-side-btn {
  width: 36px;
  height: 36px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  cursor: pointer;
  transition: all var(--transition);
  text-decoration: none;
  font-size: 0;
  position: relative;
}
.social-side-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.social-side-fb:hover { background: #1877f2; border-color: #1877f2; color: #fff; }
.social-side-messenger:hover { background: #0078ff; border-color: #0078ff; color: #fff; }
.social-side-reddit:hover { background: #ff4500; border-color: #ff4500; color: #fff; }
.social-side-li:hover { background: #0a66c2; border-color: #0a66c2; color: #fff; }
.social-side-x:hover { background: #111; border-color: #111; color: #fff; }
.social-side-comments:hover { background: var(--primary); border-color: var(--text); color: #fff; }
.social-side-heart:hover, .social-side-heart.bookmarked { color: var(--text); border-color: var(--primary); background: rgba(192,57,43,.06); }
.social-side-print:hover { background: var(--dark); border-color: var(--dark); color: #fff; }
.social-side-count { position: absolute; top: -5px; right: -5px; background: var(--primary); color: #fff; font-size: .56rem; width: 15px; height: 15px; display: flex; align-items: center; justify-content: center; font-weight: 700; border-radius: 50%; font-family: var(--font-sans); }

/* Mobile social strip — HIDDEN on desktop */
.social-strip-mobile {
  display: none;
}

/* Article Sidebar */
.article-sidebar { position: sticky; top: var(--sticky-header-offset); }
.sidebar-widget { background: var(--bg2); border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border); margin-bottom: 1.25rem; box-shadow: var(--shadow-sm); }
.widget-title { font-family: var(--font-sans); font-size: .66rem; font-weight: 700; padding: .65rem 1rem; background: var(--dark); color: rgba(255,255,255,.88); text-transform: uppercase; letter-spacing: .1em; }
.widget-tabs { display: flex; border-bottom: 1px solid var(--border); background: var(--bg3); }
.widget-tab-btn { flex: 1; padding: .48rem .4rem; background: none; border: none; border-bottom: 2px solid transparent; margin-bottom: -1px; cursor: pointer; font-size: .65rem; font-family: var(--font-sans); font-weight: 700; color: var(--text-light); transition: all var(--transition); text-transform: uppercase; letter-spacing: .07em; }
.widget-tab-btn.active { color: var(--text); border-bottom-color: var(--primary); }
.widget-tab-panel { display: none; }
.widget-tab-panel.active { display: block; }
.sidebar-articles { display: flex; flex-direction: column; }
.sidebar-article { display: flex; gap: .6rem; padding: .72rem 1rem; border-bottom: 1px solid var(--border-light); transition: background var(--transition); }
.sidebar-article:last-child { border-bottom: none; }
.sidebar-article:hover { background: var(--bg3); }
.sidebar-article-img { width: 60px; height: 47px; object-fit: cover; flex-shrink: 0; border-radius: 4px; }
.sidebar-article-content { flex: 1; display: flex; flex-direction: column; justify-content: center; gap: .18rem; }
.sidebar-article-title { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: .75rem; font-weight: 700; line-height: 1.42; color: var(--text); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.sidebar-article:hover .sidebar-article-title { color: var(--text); }
.sidebar-article-date { font-size: .65rem; color: var(--text-light); font-family: var(--font-sans); }

/* Premium sidebar promo */
.sidebar-premium-promo { border-top: 3px solid #d97706; }
.promo-header { background: var(--dark); color: rgba(255,255,255,.9); padding: .65rem 1rem; font-size: .65rem; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: .1em; }
.promo-body { padding: 1rem; background: var(--bg2); }
.promo-body p { font-size: .8rem; font-family: var(--font-sans); color: var(--text-muted); margin-bottom: .6rem; line-height: 1.55; }
.promo-price { font-size: 1rem; font-family: var(--font-sans); font-weight: 700; color: var(--dark); margin-bottom: .8rem; }
.promo-btn { display: block; text-align: center; background: #d97706; color: #fff; padding: .55rem 1rem; border-radius: 5px; font-weight: 700; font-size: .75rem; font-family: var(--font-sans); transition: background var(--transition); text-transform: uppercase; letter-spacing: .06em; }
.promo-btn:hover { background: #b45309; }

/* ===== NEXT ARTICLE AUTOLOAD ===== */
.next-articles-wrap { margin-top: 2rem; }
.next-article-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-lg); margin-bottom: 2rem; overflow: hidden; box-shadow: var(--shadow-sm); border-top: 3px solid var(--primary); }
.next-article-label { font-size: .62rem; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--text-light); padding: .7rem 1.25rem .15rem; }
.next-article-hdr { padding: .3rem 1.25rem .85rem; }
.next-article-cat { font-size: .62rem; font-family: var(--font-sans); font-weight: 700; color: var(--text); text-transform: uppercase; letter-spacing: .09em; display: inline-block; margin-bottom: .3rem; }
.next-article-ttl { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: 1.2rem; font-weight: 700; line-height: 1.32; color: var(--dark); }
.next-article-img { width: 100%; height: 250px; object-fit: cover; display: block; }
.next-article-preview-wrap { padding: .85rem 1.25rem 0; position: relative; }
.next-article-preview { max-height: 150px; overflow: hidden; position: relative; }
.next-article-preview.article-content { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: .9rem; line-height: 1.78; color: var(--text); }
.next-article-preview.article-content h2,
.next-article-preview.article-content h3,
.next-article-preview.article-content h4 { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: .95rem; font-weight: 700; margin: .8rem 0 .4rem; color: var(--dark); }
.next-article-preview.article-content p { margin-bottom: .85rem; }
.next-article-fade { position: absolute; bottom: 0; left: 0; right: 0; height: 80px; background: linear-gradient(to bottom, transparent, var(--bg2)); pointer-events: none; }
.next-article-actions { padding: .75rem 1.25rem 1.25rem; display: flex; gap: 1rem; align-items: center; }
.next-article-expand-btn {
  display: inline-block;
  padding: .58rem 1.35rem;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: var(--radius);
  font-weight: 700;
  font-size: .75rem;
  font-family: var(--font-sans);
  cursor: pointer;
  transition: background var(--transition);
  text-transform: uppercase;
  letter-spacing: .06em;
  text-decoration: none;
}
.next-article-expand-btn:hover { background: var(--primary-dark); color: #fff; }
.next-article-open-link { font-size: .75rem; font-family: var(--font-sans); color: var(--text-light); text-decoration: none; }

/* ========== PAGINATION ========== */
.pagination { display: flex; justify-content: center; gap: .3rem; margin: 2.5rem 0 1rem; flex-wrap: wrap; }
.page-link { padding: .45rem .9rem; border-radius: 5px; border: 1px solid var(--border); color: var(--text); font-size: .8rem; font-family: var(--font-sans); font-weight: 600; transition: all var(--transition); background: var(--bg2); }
.page-link:hover,.page-link.active { background: var(--primary); color: #fff; border-color: var(--text); }

/* ========== FOOTER ========== */
.site-footer { background: var(--dark2); color: rgba(255,255,255,.75); margin-top: 3rem; border-top: 3px solid var(--primary); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2.5rem; padding: 2.5rem 0 2rem; }
.footer-logo { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: 1.15rem; font-weight: 700; color: #fff; margin-bottom: .85rem; display: inline-block; }
.footer-tagline { font-size: .78rem; font-family: var(--font-sans); opacity: .55; line-height: 1.65; margin-bottom: 1.2rem; }
.footer-social { display: flex; gap: .35rem; flex-wrap: wrap; }
.social-btn { padding: .28rem .75rem; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12); border-radius: 4px; font-size: .7rem; font-family: var(--font-sans); font-weight: 600; color: rgba(255,255,255,.68); transition: all var(--transition); }
.social-btn:hover { background: var(--primary); border-color: var(--text); color: #fff; }
.footer-heading { font-size: .65rem; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: rgba(255,255,255,.38); margin-bottom: .85rem; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: .45rem; }
.footer-links a { font-size: .8rem; font-family: var(--font-sans); color: rgba(255,255,255,.58); transition: color var(--transition); }
.footer-links a:hover { color: #fff; }
.footer-contact-text { font-size: .8rem; font-family: var(--font-sans); color: rgba(255,255,255,.58); line-height: 1.65; }
.footer-contact-text a { color: var(--primary-light); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.07); padding: 1rem 0; text-align: center; font-size: .72rem; font-family: var(--font-sans); opacity: .38; }

/* ========== ALERTS ========== */
.alert { padding: .75rem 1.1rem; margin-bottom: 1rem; font-size: .85rem; font-family: var(--font-sans); font-weight: 500; border-radius: var(--radius); }
.alert-success { background: #d1fae5; color: #065f46; border-left: 3px solid #059669; }
.alert-danger { background: #fee2e2; color: #991b1b; border-left: 3px solid var(--primary); }

/* ========== EMPTY STATE ========== */
.empty-state { text-align: center; padding: 3rem 1rem; color: var(--text-light); font-family: var(--font-sans); }
.empty-state a { color: var(--text); }

/* ========== AUTH PAGES ========== */
.auth-main { padding: 3rem 0 4rem; background: var(--bg); }
.auth-card { max-width: 460px; margin: 0 auto; background: var(--bg2); padding: 2.5rem; border-radius: var(--radius-lg); border: 1px solid var(--border); box-shadow: var(--shadow-md); }
.auth-header { text-align: center; margin-bottom: 2rem; }
.auth-title { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: 1.5rem; font-weight: 700; color: var(--dark); }
.auth-subtitle { color: var(--text-light); margin-top: .4rem; font-size: .82rem; font-family: var(--font-sans); }
.social-login { display: flex; flex-direction: column; gap: .55rem; margin-bottom: 1.25rem; }
.social-btn-lg { display: flex; align-items: center; gap: .75rem; padding: .65rem 1.1rem; border-radius: var(--radius); font-size: .85rem; font-family: var(--font-sans); font-weight: 600; border: 1.5px solid var(--border); background: var(--bg2); color: var(--text); transition: all var(--transition); }
.social-btn-lg:hover { border-color: #bbb; box-shadow: var(--shadow-sm); }
.social-google:hover { border-color: #4285f4; }
.social-facebook:hover { border-color: #1877f2; }
.social-linkedin:hover { border-color: #0a66c2; }
.social-twitter:hover { border-color: #000; }
.auth-divider { display: flex; align-items: center; gap: 1rem; color: var(--text-light); font-size: .75rem; font-family: var(--font-sans); margin: .75rem 0; }
.auth-divider::before,.auth-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.auth-form { display: flex; flex-direction: column; gap: .9rem; }
.pw-toggle { position: absolute; right: .75rem; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; color: var(--text-light); }
.password-wrap { position: relative; }
.btn-auth-submit { background: var(--primary); color: #fff; border: none; padding: .75rem; border-radius: var(--radius); font-size: .88rem; font-family: var(--font-sans); font-weight: 700; cursor: pointer; transition: background var(--transition); margin-top: .35rem; text-transform: uppercase; letter-spacing: .05em; }
.btn-auth-submit:hover { background: var(--primary-dark); }
.auth-footer { text-align: center; margin-top: 1.5rem; color: var(--text-light); font-size: .82rem; font-family: var(--font-sans); }
.auth-link { color: var(--text); font-weight: 600; }
.auth-link:hover { text-decoration: none; }

/* ========== HEADER USER AREA ========== */
.header-top-right { display: flex; align-items: center; gap: .85rem; }
.header-user-area { display: flex; align-items: center; gap: .4rem; }
.header-login-btn { font-size: .7rem; font-family: var(--font-sans); color: rgba(255,255,255,.68); transition: color var(--transition); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; }
.header-login-btn:hover { color: #fff; }
.header-subscribe-btn { background: var(--primary); color: #fff; padding: .22rem .72rem; border-radius: 3px; font-size: .66rem; font-family: var(--font-sans); font-weight: 700; transition: background var(--transition); text-transform: uppercase; letter-spacing: .05em; }
.header-subscribe-btn:hover { background: var(--primary-dark); }
.header-install-btn {
  border: 1px solid var(--border);
  background: var(--bg2);
  color: var(--text);
  border-radius: 999px;
  padding: .42rem .82rem;
  font-size: .74rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
}
.header-install-btn:hover {
  border-color: var(--text);
  color: var(--text);
}
.user-menu { position: relative; }
.user-menu-btn { display: flex; align-items: center; gap: .4rem; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); padding: .2rem .55rem .2rem .3rem; border-radius: 20px; cursor: pointer; font-size: .72rem; font-family: var(--font-sans); color: rgba(255,255,255,.85); transition: background var(--transition); }
.user-menu-btn:hover { background: rgba(255,255,255,.15); }
.user-avatar-img { width: 22px; height: 22px; border-radius: 50%; object-fit: cover; }
.user-avatar-initials { width: 22px; height: 22px; border-radius: 50%; background: var(--primary); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .7rem; color: #fff; font-family: var(--font-sans); }
.user-menu-name { max-width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.user-dropdown { position: absolute; top: calc(100% + 7px); right: 0; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); min-width: 180px; box-shadow: var(--shadow-lg); z-index: 300; display: none; }
.user-dropdown.open { display: block; }
.dropdown-item { display: block; padding: .6rem 1rem; font-size: .8rem; font-family: var(--font-sans); color: var(--text); transition: background var(--transition); }
.dropdown-item:hover { background: var(--bg3); }
.dropdown-logout { color: var(--text); }
.dropdown-premium-badge { display: block; padding: .35rem 1rem; font-size: .7rem; font-family: var(--font-sans); font-weight: 700; color: #92400e; background: #fef3c7; border-bottom: 1px solid var(--border); }

/* ========== PREMIUM BADGES ========== */
.article-badges { display: flex; gap: .4rem; align-items: center; flex-wrap: wrap; margin-bottom: .75rem; }
.premium-badge { display: inline-block; padding: .2rem .65rem; border-radius: 3px; font-size: .62rem; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; background: #92400e; color: #fef3c7; }
.card-premium { display: inline-block; font-size: .6rem; font-family: var(--font-sans); background: #fef3c7; color: #92400e; padding: .1rem .4rem; border-radius: 3px; font-weight: 700; }

/* ========== PAYWALL ========== */
.article-content-preview { position: relative; max-height: 280px; overflow: hidden; }
.preview-fade { position: absolute; bottom: 0; left: 0; right: 0; height: 120px; background: linear-gradient(transparent, var(--bg2)); }
.paywall-box { background: var(--bg2); border: 1.5px solid var(--border); border-top: 3px solid #d97706; border-radius: var(--radius-lg); padding: 2.5rem; text-align: center; margin: 2rem 0; box-shadow: var(--shadow); }
.paywall-icon { font-size: 2rem; margin-bottom: .6rem; }
.paywall-title { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: 1.15rem; font-weight: 700; color: var(--dark); margin-bottom: .6rem; }
.paywall-text { color: var(--text-muted); margin-bottom: 1.5rem; max-width: 420px; margin-left: auto; margin-right: auto; font-size: .85rem; font-family: var(--font-sans); }
.paywall-actions { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem; }
.paywall-btn { padding: .62rem 1.5rem; border-radius: var(--radius); font-weight: 700; font-size: .85rem; font-family: var(--font-sans); transition: all var(--transition); border: 1.5px solid var(--border); background: var(--bg3); color: var(--text); }
.paywall-btn:hover { border-color: var(--text); color: var(--primary); }
.paywall-btn-primary { background: #d97706; color: #fff; border: none; }
.paywall-btn-primary:hover { background: #b45309; }
.paywall-plans-preview { font-size: .75rem; font-family: var(--font-sans); color: var(--text-light); display: flex; justify-content: center; gap: .75rem; flex-wrap: wrap; }

/* ========== SUBSCRIBE PAGE ========== */
.subscribe-hero { background: var(--dark); color: #fff; padding: 3.5rem 0; text-align: center; border-bottom: 3px solid var(--primary); }
.subscribe-badge { display: inline-block; background: rgba(192,57,43,.18); border: 1px solid rgba(192,57,43,.3); color: #f87171; padding: .25rem .9rem; border-radius: 20px; font-size: .7rem; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 1rem; }
.subscribe-title { font-family: Verdana, Geneva, Tahoma, sans-serif; font-size: 2rem; font-weight: 700; margin-bottom: .75rem; }
.subscribe-subtitle { font-size: 1rem; font-family: var(--font-sans); opacity: .72; max-width: 440px; margin: 0 auto; }
.subscribe-active { text-align: center; padding: 4rem 2rem; }
.subscribe-active-icon { font-size: 2.5rem; margin-bottom: .85rem; }
.subscribe-active h2 { font-family: var(--font-serif); font-size: 1.5rem; margin-bottom: .85rem; }

/* ========== RESPONSIVE ========== */
@media (max-width: 1100px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-sidebar { flex-direction: row; flex-wrap: wrap; gap: .8rem; }
  .hero-side-item { width: calc(50% - .4rem); }
  .articles-grid-4 { grid-template-columns: repeat(3, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
  .articles-grid { grid-template-columns: repeat(2, 1fr); }
  .article-layout { grid-template-columns: 1fr; }
  .article-sidebar { display: none !important; }
  .social-sidebar { display: none !important; }
  .article-content-row { grid-template-columns: 1fr; }
  .articles-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .social-strip-mobile { display: flex !important; }
}
@media (max-width: 640px) {
  .logo-text { font-size: 1.45rem; }
  .header-search { max-width: 100%; }
  .header-main-inner { flex-wrap: wrap; gap: .65rem; }
  .articles-grid { grid-template-columns: 1fr; }
  .articles-grid-4 { grid-template-columns: 1fr 1fr; }
  .mobile-menu-btn { display: block; }
  .nav-list { display: none; flex-direction: column; width: 100%; }
  .nav-list.open { display: flex; }
  .nav-link { border-bottom: 1px solid var(--border-light); }
  .hero-sidebar { flex-direction: column; gap: .8rem; }
  .hero-side-item { width: 100%; }
  .form-row { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .article-title { font-size: 1.7rem; }
  .hero-title { font-size: 1.4rem; }

  .article-sources-trigger {
    width: 100%;
    justify-content: center;
  }

  .sources-modal-dialog {
    width: calc(100vw - 1rem);
    max-height: calc(100vh - 1rem);
    margin: .5rem auto;
    border-radius: 16px;
  }

  .sources-modal-head {
    padding: .85rem .9rem;
  }

  .sources-modal-body {
    padding: .75rem .75rem .9rem;
  }

  .sources-modal-item {
    flex-direction: column;
    align-items: stretch;
    gap: .55rem;
  }

  .source-copy-btn {
    width: 100%;
  }
}

/* ===================== MATERIAL DESIGN 3 REDESIGN OVERRIDE ===================== */
:root {
  --m3-primary: #0b57d0;
  --m3-on-primary: #ffffff;
  --m3-primary-container: #d3e3fd;
  --m3-on-primary-container: #041e49;
  --m3-secondary: #0b57d0;
  --m3-secondary-container: #d3e3fd;
  --m3-tertiary: #9a5d00;
  --m3-tertiary-container: #fbe7c4;
  --m3-surface: #ffffff;
  --m3-surface-container-low: #ffffff;
  --m3-surface-container: #f6f7f9;
  --m3-surface-container-high: #f1f3f5;
  --m3-surface-container-highest: #e9edf1;
  --m3-outline: #97a0ad;
  --m3-outline-variant: #c8d0dc;
  --m3-on-surface: #111827;
  --m3-on-surface-variant: #4b5563;
  --m3-error: #ba1a1a;
  --m3-error-container: #ffdad6;
  --m3-success: #1f7a43;
  --m3-warning: #9a5d00;
  --m3-radius-xs: 10px;
  --m3-radius-sm: 14px;
  --m3-radius-md: 18px;
  --m3-radius-lg: 24px;
  --m3-radius-xl: 30px;
  --m3-shadow-1: 0 1px 2px rgba(15, 29, 49, .08), 0 1px 4px rgba(15, 29, 49, .06);
  --m3-shadow-2: 0 3px 8px rgba(15, 29, 49, .12), 0 8px 18px rgba(15, 29, 49, .08);
  --m3-shadow-3: 0 6px 18px rgba(15, 29, 49, .14), 0 14px 32px rgba(15, 29, 49, .11);
  --font-sans: 'Manrope', 'Segoe UI', 'Helvetica Neue', sans-serif;
  --font-serif: 'Manrope', 'Segoe UI', 'Helvetica Neue', sans-serif;
  --transition: .24s cubic-bezier(.2, .7, .2, 1);
}

html {
  scroll-behavior: auto;
  scrollbar-gutter: stable;
}

body {
  background: var(--m3-surface);
  color: var(--m3-on-surface);
  font-family: var(--font-sans);
  line-height: 1.65;
}

.site-main,
.site-wrapper {
  position: relative;
  z-index: 1;
}

.container {
  width: min(1240px, calc(100% - 2.4rem));
  padding: 0;
}

a {
  color: inherit;
}

h1, h2, h3, h4 {
  font-family: var(--font-serif);
  letter-spacing: -.01em;
}

@keyframes m3FadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Header */
.site-header {
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  background: #ffffff;
  border-bottom: 1px solid var(--m3-outline-variant);
  box-shadow: none;
}

.header-top {
  background: transparent;
  border-bottom: 1px solid var(--m3-outline-variant);
  color: var(--m3-on-surface-variant);
  font-size: .8rem;
  padding: .5rem 0;
}

.header-date {
  font-weight: 600;
  letter-spacing: .01em;
  text-transform: none;
  opacity: 1;
}

.header-top-inner,
.header-top-right {
  display: flex;
  align-items: center;
  gap: .65rem;
}

.header-top-right {
  margin-left: auto;
}

.header-social {
  gap: .4rem;
}

.social-link {
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  color: var(--m3-on-surface-variant);
  background: var(--m3-surface-container-low);
  padding: .34rem .7rem;
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .01em;
  text-transform: none;
}

.social-link:hover {
  color: var(--m3-primary);
  border-color: color-mix(in srgb, var(--m3-primary) 45%, var(--m3-outline-variant));
  background: color-mix(in srgb, var(--m3-primary-container) 48%, #fff);
}

.header-top-search-link {
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  color: var(--m3-primary);
  background: var(--m3-surface-container-low);
  padding: .34rem .78rem;
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .01em;
}

.header-top-search-link:hover {
  background: var(--m3-primary-container);
}

.header-main {
  border-bottom: 0;
  background: transparent;
  padding: .95rem 0;
}

.header-main-inner {
  gap: 1rem;
}

.site-logo {
  background: var(--m3-surface-container-low);
  border: 1px solid var(--m3-outline-variant);
  border-radius: 999px;
  padding: .55rem 1rem;
}

.logo-text {
  font-family: var(--font-serif);
  font-style: normal;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--m3-on-surface);
  letter-spacing: -.02em;
}

.header-search {
  flex: 1;
  max-width: 520px;
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface-container-low);
  border-radius: 999px;
  min-height: 48px;
}

.header-search:focus-within {
  border-color: var(--m3-primary);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--m3-primary) 20%, transparent);
}

.search-input {
  font-size: .93rem;
  font-weight: 500;
  color: var(--m3-on-surface);
  padding: .7rem 1.1rem;
}

.search-input::placeholder {
  color: color-mix(in srgb, var(--m3-on-surface-variant) 68%, transparent);
}

.search-btn {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  margin-right: 2px;
}

.search-btn:hover {
  background: color-mix(in srgb, var(--m3-primary-container) 75%, #fff);
  color: var(--m3-primary);
}

.main-nav {
  border-bottom: 0;
  background: transparent;
  padding-bottom: .85rem;
}

.nav-list {
  display: flex;
  gap: .45rem;
}

.nav-link {
  padding: .52rem .95rem;
  font-size: .79rem;
  text-transform: none;
  border-radius: 999px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--m3-on-surface-variant);
  letter-spacing: .01em;
  font-weight: 700;
}

.nav-link::after {
  display: none;
}

.nav-link:hover {
  color: var(--m3-primary);
  border-color: color-mix(in srgb, var(--m3-primary) 30%, var(--m3-outline-variant));
  background: color-mix(in srgb, var(--m3-primary-container) 62%, #fff);
}

.nav-item-more {
  position: relative;
}

.nav-more-btn {
  display: inline-flex;
  align-items: center;
  gap: .28rem;
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface-container-low);
  cursor: pointer;
}

.nav-more-caret {
  font-size: .66rem;
  line-height: 1;
}

.nav-more-menu {
  position: absolute;
  top: calc(100% + .45rem);
  right: 0;
  min-width: 220px;
  max-width: min(86vw, 320px);
  max-height: min(60vh, 440px);
  overflow-y: auto;
  display: none;
  padding: .4rem;
  border-radius: 14px;
  border: 1px solid var(--m3-outline-variant);
  background: #fff;
  box-shadow: var(--m3-shadow-2);
  z-index: 380;
}

.nav-item-more.open .nav-more-menu {
  display: grid;
  gap: .2rem;
}

.nav-more-link {
  display: block;
  padding: .52rem .66rem;
  border-radius: 10px;
  color: var(--m3-on-surface);
  font-size: .8rem;
  font-weight: 600;
  line-height: 1.3;
}

.nav-more-link:hover {
  color: var(--m3-primary);
  background: color-mix(in srgb, var(--m3-primary-container) 65%, #fff);
}

.header-login-btn,
.header-subscribe-btn,
.header-install-btn {
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 700;
  text-transform: none;
  letter-spacing: .01em;
}

.header-login-btn {
  color: var(--m3-primary);
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface-container-low);
  padding: .45rem .9rem;
}

.header-login-btn:hover {
  background: var(--m3-primary-container);
}

.header-subscribe-btn {
  background: var(--m3-primary);
  color: var(--m3-on-primary);
  padding: .45rem .9rem;
  border: 1px solid transparent;
}

.header-subscribe-btn:hover {
  filter: brightness(.94);
}

.header-install-btn {
  color: var(--m3-primary);
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface-container-low);
  padding: .45rem .9rem;
}

.header-install-btn:hover {
  background: var(--m3-primary-container);
}

.user-menu-btn {
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface-container-low);
  color: var(--m3-on-surface);
  padding: .28rem .7rem .28rem .3rem;
}

.user-dropdown {
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-md);
  box-shadow: var(--m3-shadow-2);
}

.dropdown-item {
  font-size: .83rem;
}

.dropdown-item:hover {
  background: var(--m3-surface-container-low);
}

/* Hero and sections */
.hero-section,
.section,
.section:nth-child(odd),
.latest-section,
.category-hero,
.search-hero,
.subscribe-hero {
  background: transparent !important;
  border: 0;
}

.hero-section,
.section {
  padding: 1.15rem 0 1.6rem;
}

.hero-grid {
  gap: 1.1rem;
  align-items: start;
}

.hero-main-link {
  background: var(--m3-surface-container-low);
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-lg);
  overflow: hidden;
  box-shadow: var(--m3-shadow-1);
}

.hero-main-link:hover {
  box-shadow: var(--m3-shadow-3);
  transform: translateY(-2px);
}

.hero-image-wrap {
  aspect-ratio: 16/8.7;
}

.hero-image-placeholder,
.side-item-placeholder,
.card-no-image {
  background: linear-gradient(130deg, #dbe8f8, #c9d7eb);
}

.hero-content {
  background: transparent;
  padding: 1.05rem 1.1rem 1.2rem;
}

.hero-category,
.side-item-cat,
.card-category,
.cat-badge {
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.hero-title {
  font-family: var(--font-serif);
  font-size: clamp(1.3rem, 2.3vw, 2rem);
  color: var(--m3-on-surface);
  line-height: 1.25;
}

.hero-excerpt {
  color: var(--m3-on-surface-variant);
  font-size: .9rem;
}

.hero-meta,
.side-item-date,
.card-meta,
.cat-count,
.search-result-count {
  color: color-mix(in srgb, var(--m3-on-surface-variant) 85%, transparent);
  font-size: .75rem;
}

.hero-side-item {
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-md);
  background: var(--m3-surface-container-low);
  box-shadow: none;
}

.hero-side-item:hover {
  transform: translateY(-2px);
  box-shadow: var(--m3-shadow-2);
}

.side-item-image {
  width: 104px;
}

.section-header {
  border: 0;
  margin-bottom: .9rem;
  padding-bottom: .2rem;
}

.section-title {
  font-family: var(--font-serif);
  color: var(--m3-on-surface);
  font-size: 1.08rem;
  text-transform: none;
  letter-spacing: -.01em;
}

.section-more {
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface-container-low);
  border-radius: 999px;
  padding: .36rem .8rem;
  text-transform: none;
  letter-spacing: 0;
  color: var(--m3-on-surface-variant);
}

.section-more:hover {
  color: var(--m3-primary);
  border-color: color-mix(in srgb, var(--m3-primary) 35%, var(--m3-outline-variant));
}

/* Cards */
.articles-grid,
.articles-grid-4 {
  gap: 1rem;
}

.article-card {
  background: var(--m3-surface-container-low);
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-md);
  box-shadow: none;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.articles-grid .article-card:nth-child(2n) { animation-delay: .04s; }
.articles-grid .article-card:nth-child(3n) { animation-delay: .08s; }

.article-card:hover {
  border-color: color-mix(in srgb, var(--m3-primary) 30%, var(--m3-outline-variant));
  box-shadow: var(--m3-shadow-2);
  transform: translateY(-3px);
}

.card-image-link {
  border-bottom: 1px solid var(--m3-outline-variant);
}

.card-body {
  padding: .92rem .95rem 1rem;
}

.card-title,
.card-title-sm {
  font-family: var(--font-serif);
  font-size: 1rem;
  line-height: 1.35;
}

.card-title-sm {
  font-size: .92rem;
}

.card-title a:hover {
  color: var(--m3-primary);
}

.card-excerpt {
  color: var(--m3-on-surface-variant);
  font-size: .84rem;
}

.card-premium,
.premium-badge {
  border-radius: 999px;
  background: var(--m3-tertiary-container);
  color: var(--m3-tertiary);
  font-size: .64rem;
  padding: .16rem .5rem;
  letter-spacing: .02em;
}

.card-meta {
  border-top: 1px solid var(--m3-outline-variant);
  padding-top: .55rem;
}

/* Category/Search/Auth/Subscribe wrappers */
.category-hero,
.search-hero,
.subscribe-hero {
  padding: 1rem 0 .6rem;
}

.cat-badge,
.subscribe-badge {
  border-radius: 999px;
  padding: .24rem .72rem;
  background: var(--m3-primary-container) !important;
  color: var(--m3-primary);
  border: 1px solid color-mix(in srgb, var(--m3-primary) 34%, transparent);
}

.cat-page-title,
.search-page-title,
.subscribe-title {
  font-family: var(--font-serif);
  font-size: clamp(1.35rem, 2.2vw, 2rem);
  color: var(--m3-on-surface);
}

.search-page-form {
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface-container-low);
  overflow: visible;
  max-width: 720px;
}

.search-page-input {
  color: var(--m3-on-surface);
  background: transparent;
  padding: .8rem 1rem;
}

.search-page-form-autocomplete {
  display: flex;
  align-items: center;
  gap: .35rem;
  padding: .2rem;
}

.search-autocomplete-wrap {
  position: relative;
  flex: 1;
}

.search-autocomplete-wrap .search-page-input {
  width: 100%;
  border-radius: 999px;
}

.search-suggestions {
  position: absolute;
  top: calc(100% + .45rem);
  left: 0;
  right: 0;
  z-index: 60;
  background: #fff;
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-sm);
  box-shadow: var(--m3-shadow-2);
  overflow: auto;
  max-height: 360px;
}

.search-suggestion-item {
  display: block;
  padding: .58rem .76rem;
  border-bottom: 1px solid var(--m3-outline-variant);
}

.search-suggestion-item:last-child {
  border-bottom: 0;
}

.search-suggestion-item:hover,
.search-suggestion-item.active {
  background: var(--m3-primary-container);
}

.search-suggestion-title {
  display: block;
  font-size: .86rem;
  font-weight: 700;
  color: var(--m3-on-surface);
  margin-bottom: .1rem;
}

.search-suggestion-meta {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .72rem;
  color: var(--m3-on-surface-variant);
}

.search-suggestion-cat {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .08rem .45rem;
  background: var(--m3-primary-container);
  color: var(--m3-primary);
  font-weight: 700;
}

.search-suggestion-all {
  font-weight: 700;
  color: var(--m3-primary);
}

.search-page-btn {
  background: var(--m3-primary);
  border-radius: 999px;
  margin: 4px;
  padding: .52rem 1.2rem;
  font-size: .84rem;
  letter-spacing: .01em;
  text-transform: none;
}

.auth-main {
  padding: 1.5rem 0 2.2rem;
}

.auth-card,
.success-card,
.subscribe-active,
.pricing-card,
.payment-methods-info,
.subscribe-faq,
.faq-item,
.empty-state,
.paywall-box,
.comment-form-wrap,
.sidebar-widget,
.sidebar-premium-promo,
.article-body,
.article-sidebar,
.article-tags,
.comments-section,
.table-card {
  background: var(--m3-surface-container-low);
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-lg);
  box-shadow: var(--m3-shadow-1);
}

.article-sidebar {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.article-sidebar .sidebar-widget {
  margin-bottom: 0;
}

.auth-card,
.success-card,
.subscribe-active,
.paywall-box,
.empty-state {
  max-width: 720px;
  margin: 1rem auto;
  padding: 1.2rem;
}

.auth-title,
.success-title,
.comments-title,
.comment-form-title,
.faq-title,
.paywall-title {
  font-family: var(--font-serif);
  color: var(--m3-on-surface);
}

.auth-subtitle,
.success-text,
.paywall-text,
.subscribe-subtitle,
.faq-item p {
  color: var(--m3-on-surface-variant);
}

.auth-form .form-input,
.auth-form .form-textarea,
.auth-form .form-select,
.comment-form .form-input,
.comment-form .form-textarea,
.form-input,
.form-textarea,
.form-select {
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface);
  border-radius: var(--m3-radius-sm);
  color: var(--m3-on-surface);
}

.auth-form .form-input:focus,
.auth-form .form-textarea:focus,
.comment-form .form-input:focus,
.comment-form .form-textarea:focus,
.form-input:focus,
.form-textarea:focus,
.form-select:focus {
  outline: none;
  border-color: var(--m3-primary);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--m3-primary) 18%, transparent);
}

.btn-auth-submit,
.btn-submit,
.btn-subscribe,
.paywall-btn-primary,
.promo-btn,
.btn-subscribe-gold,
.btn-stripe,
.btn-paysera {
  border-radius: 999px;
  border: 0;
  background: var(--m3-primary);
  color: var(--m3-on-primary);
  font-weight: 700;
  letter-spacing: .01em;
  padding: .68rem 1.2rem;
}

.btn-auth-submit:hover,
.btn-submit:hover,
.btn-subscribe:hover,
.paywall-btn-primary:hover,
.promo-btn:hover,
.btn-subscribe-gold:hover,
.btn-stripe:hover,
.btn-paysera:hover {
  filter: brightness(.93);
}

.btn-secondary-link,
.paywall-btn,
.btn-secondary {
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface);
  color: var(--m3-on-surface-variant);
}

.alert {
  border-radius: var(--m3-radius-sm);
  font-weight: 600;
  border: 1px solid transparent;
}

.alert-success {
  background: color-mix(in srgb, var(--m3-success) 13%, #fff);
  border-color: color-mix(in srgb, var(--m3-success) 45%, transparent);
  color: color-mix(in srgb, var(--m3-success) 85%, #111);
}

.alert-danger {
  background: var(--m3-error-container);
  border-color: color-mix(in srgb, var(--m3-error) 34%, transparent);
  color: color-mix(in srgb, var(--m3-error) 80%, #111);
}

.alert-warning {
  background: color-mix(in srgb, var(--m3-warning) 16%, #fff);
  border-color: color-mix(in srgb, var(--m3-warning) 30%, transparent);
  color: color-mix(in srgb, var(--m3-warning) 92%, #111);
}

/* Article page */
.article-main {
  padding: 1rem 0 2rem;
}

.article-layout {
  gap: 1.05rem;
}

.article-body {
  padding: 1.15rem;
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: .36rem;
  color: var(--m3-on-surface-variant);
  font-size: .76rem;
  margin-bottom: .85rem;
}

.breadcrumb a {
  color: var(--m3-primary);
}

.article-title {
  font-size: clamp(1.52rem, 3vw, 2.34rem);
  line-height: 1.18;
  margin-bottom: .65rem;
  color: var(--m3-on-surface);
}

.article-lead {
  color: var(--m3-on-surface-variant);
  font-size: 1rem;
  margin-bottom: .92rem;
}

.article-meta,
.article-meta-updated {
  color: color-mix(in srgb, var(--m3-on-surface-variant) 86%, transparent);
  font-size: .79rem;
}

.article-image-wrap {
  border-radius: var(--m3-radius-md);
  overflow: hidden;
  border: 1px solid var(--m3-outline-variant);
  position: relative;
}

.article-inline-image-wrap {
  position: relative;
  display: block;
  border-radius: var(--m3-radius-sm);
  overflow: hidden;
  margin: 1rem 0;
}

.article-inline-image-wrap > img,
.article-inline-image-wrap > a > img {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 !important;
  border-radius: inherit;
}

.article-image-alt-toggle {
  position: absolute;
  bottom: .72rem;
  right: .72rem;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .65);
  background: rgba(11, 18, 32, .62);
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 16px rgba(7, 11, 19, .28);
  transition: background .2s ease, transform .2s ease;
}

.article-image-alt-toggle:hover {
  background: rgba(11, 18, 32, .84);
  transform: translateY(-1px);
}

.article-image-alt-panel {
  position: absolute;
  right: 2.95rem;
  bottom: .72rem;
  width: min(540px, calc(100% - 4.6rem));
  min-height: 32px;
  background: rgba(10, 16, 28, .88);
  color: #fff;
  padding: .38rem .72rem;
  display: flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .24);
  box-shadow: 0 8px 18px rgba(7, 11, 19, .3);
  transform: translateX(calc(100% + .65rem));
  opacity: 0;
  pointer-events: none;
  transition: transform .22s ease, opacity .18s ease;
  z-index: 2;
}

.article-image-alt-panel.open {
  transform: translateX(0);
  opacity: 1;
  pointer-events: auto;
}

.article-inline-image-alt-panel {
  width: min(520px, calc(100% - 4.4rem));
}

.article-image-alt-caption {
  font-size: .82rem;
  font-weight: 600;
  line-height: 1.35;
  color: rgba(255, 255, 255, .98);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
}

@media (max-width: 760px) {
  .article-image-alt-panel {
    right: 3rem;
    bottom: .65rem;
    width: calc(100% - 4rem);
    min-height: 30px;
    padding: .34rem .62rem;
  }

  .article-image-alt-toggle {
    bottom: .65rem;
    right: .65rem;
  }

  .article-image-alt-caption {
    font-size: .77rem;
  }

  .article-inline-image-alt-panel {
    width: calc(100% - 3.95rem);
  }
}

.article-content {
  margin-top: 1.1rem;
  color: var(--m3-on-surface);
  font-size: 1.03rem;
}

.article-content p,
.article-content li,
.article-content blockquote {
  color: var(--m3-on-surface);
}

.article-content h2,
.article-content h3 {
  margin-top: 1.3em;
  margin-bottom: .5em;
}

.article-content a {
  color: var(--m3-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.article-content img {
  border-radius: var(--m3-radius-sm);
}

.article-content figure {
  margin: 1rem 0;
}

.article-content figure .article-inline-image-wrap {
  margin: 0;
}

.article-content-preview {
  max-height: 330px;
}

.preview-fade {
  background: linear-gradient(transparent, #ffffff);
}

.article-tags {
  margin-top: 1.1rem;
  padding: .82rem 1rem;
}

.tag-item {
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  padding: .2rem .62rem;
  background: var(--m3-surface);
  font-size: .75rem;
  display: inline-block;
  margin-right: .35rem;
  margin-top: .35rem;
}

.comments-section {
  margin-top: 1.15rem;
  padding: 1rem 0 0;
  background: transparent !important;
  border: 0 !important;
  border-top: 1px solid var(--m3-outline-variant) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.comments-list {
  margin-bottom: .9rem;
}

.comment {
  display: flex;
  gap: .78rem;
  padding: .65rem 0;
  border-bottom: 0;
}

.comment + .comment {
  border-top: 1px solid color-mix(in srgb, var(--m3-outline-variant) 85%, transparent);
}

.comment:last-child {
  border-bottom: 0;
}

.comment-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--m3-primary-container);
  color: var(--m3-primary);
  font-weight: 700;
  display: grid;
  place-items: center;
}

.comment-author {
  font-size: .86rem;
}

.comment-date {
  font-size: .72rem;
  color: var(--m3-on-surface-variant);
}

.comment-text {
  color: var(--m3-on-surface);
  font-size: .89rem;
}

.no-comments {
  margin-bottom: .9rem;
}

.comment-form-wrap {
  margin-top: .2rem;
  padding: .95rem 0 0;
  background: transparent !important;
  border: 0 !important;
  border-top: 1px solid var(--m3-outline-variant) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.comment-form-title {
  margin-bottom: .95rem;
}

.reading-toolbar,
.social-sidebar,
.social-strip-mobile {
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  background: #ffffff;
  box-shadow: var(--m3-shadow-1);
}

.reading-toolbar {
  display: inline-flex;
  gap: .35rem;
  padding: .28rem;
  margin: .95rem 0;
}

.read-tool-btn {
  border: 0;
  background: transparent;
  border-radius: 999px;
  width: 34px;
  height: 34px;
  font-weight: 700;
  color: var(--m3-on-surface-variant);
}

.read-tool-btn:hover,
.read-tool-btn.active {
  color: var(--m3-primary);
  background: var(--m3-primary-container);
}

.social-side-btn,
.social-strip-btn {
  border-radius: 50%;
  border: 0;
  color: var(--m3-on-surface-variant);
}

.social-side-btn:hover,
.social-strip-btn:hover {
  color: var(--m3-primary);
  background: var(--m3-primary-container);
}

.social-side-heart.bookmarked,
.ss-heart.bookmarked {
  color: #c62828;
}

.widget-tabs {
  display: flex;
  gap: .4rem;
  padding: .7rem;
  border-bottom: 1px solid var(--m3-outline-variant);
}

.widget-tab-btn {
  flex: 1;
  border: 1px solid transparent;
  background: transparent;
  border-radius: 999px;
  padding: .42rem .6rem;
  font-size: .78rem;
  font-weight: 700;
  color: var(--m3-on-surface-variant);
}

.widget-tab-btn.active {
  border-color: color-mix(in srgb, var(--m3-primary) 38%, transparent);
  background: var(--m3-primary-container);
  color: var(--m3-primary);
}

.sidebar-article {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: .62rem;
  padding: .65rem .75rem;
  border-bottom: 1px solid var(--m3-outline-variant);
}

.sidebar-article:last-child {
  border-bottom: 0;
}

.sidebar-article-img {
  border-radius: var(--m3-radius-xs);
  width: 80px;
  height: 60px;
  object-fit: cover;
}

.sidebar-article-title {
  font-size: .8rem;
  font-weight: 700;
}

.sidebar-article-date {
  color: var(--m3-on-surface-variant);
  font-size: .7rem;
}

/* Article page: remove rounded/bordered wrappers, keep image rounding */
.article-main .article-body,
.article-main .comments-section,
.article-main .comment-form-wrap,
.article-main .next-article-card {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.article-main .comments-section,
.article-main .comment-form-wrap {
  padding-top: 0;
}

.article-main .comments-section {
  border-top: 0 !important;
}

.article-main .comment + .comment {
  border-top: 0;
}

.article-main .article-sidebar {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.article-main .article-sidebar .sidebar-widget {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible;
}

.article-main .article-sidebar .widget-tabs {
  background: transparent !important;
  border-bottom: 0 !important;
  padding: .25rem 0 .55rem;
}

.article-main .article-sidebar .widget-tab-btn {
  background: transparent !important;
}

.article-main .article-sidebar .sidebar-articles {
  gap: .35rem;
}

.article-main .article-sidebar .sidebar-article {
  border-bottom: 0 !important;
  padding: .58rem 0;
}

.article-main .next-article-card {
  margin-bottom: 1.5rem;
}

.article-main .next-article-img {
  border-radius: var(--m3-radius-sm);
}

/* Static/info pages: remove boxed frames and sidebar lines */
.static-page-main .static-page-hero-shell,
.static-page-main .static-page-card {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.static-page-main .article-sidebar {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.static-page-main .article-sidebar .sidebar-widget {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible;
  margin-bottom: 0;
}

.static-page-main .article-sidebar .widget-tabs {
  background: transparent !important;
  border-bottom: 0 !important;
  padding: .25rem 0 .55rem;
}

.static-page-main .article-sidebar .widget-tab-btn {
  background: transparent !important;
}

.static-page-main .article-sidebar .sidebar-articles {
  gap: .35rem;
}

.static-page-main .article-sidebar .sidebar-article {
  border-bottom: 0 !important;
  padding: .58rem 0;
}

/* Pricing */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin: 1rem 0;
}

.pricing-card {
  padding: 1rem;
}

.pricing-card-featured {
  border-color: color-mix(in srgb, var(--m3-primary) 42%, var(--m3-outline-variant));
  box-shadow: var(--m3-shadow-2);
}

.pricing-badge,
.pricing-badge-gold {
  display: inline-flex;
  border-radius: 999px;
  padding: .24rem .7rem;
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .02em;
  background: var(--m3-primary-container);
  color: var(--m3-primary);
  margin-bottom: .55rem;
}

.pricing-plan {
  font-size: 1.14rem;
}

.pricing-price {
  display: flex;
  align-items: baseline;
  gap: .15rem;
  margin: .5rem 0 .75rem;
}

.price-amount {
  font-size: 2rem;
  font-weight: 800;
  line-height: 1;
}

.price-period,
.price-currency,
.pricing-monthly-equiv {
  color: var(--m3-on-surface-variant);
  font-size: .78rem;
}

.pricing-features {
  list-style: none;
  display: grid;
  gap: .45rem;
  margin-bottom: 1rem;
  color: var(--m3-on-surface);
  font-size: .86rem;
}

.pm-logos {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}

.pm-badge {
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  padding: .2rem .65rem;
  font-size: .72rem;
  background: var(--m3-surface);
}

/* Footer */
.site-footer {
  margin-top: 1.7rem;
  background: #0f172a;
  border-top: 0;
  padding: 1.3rem 0 1rem;
}

.footer-grid {
  gap: 1.1rem;
}

.footer-logo {
  font-family: var(--font-serif);
  font-size: 1.2rem;
}

.footer-tagline,
.footer-contact-text,
.footer-links a,
.footer-bottom {
  color: rgba(226, 232, 240, .9);
}

.footer-heading,
.footer-logo {
  color: #ffffff;
}

.footer-social .social-btn {
  display: inline-flex;
  border-radius: 999px;
  border: 1px solid rgba(226, 232, 240, .35);
  padding: .3rem .68rem;
  font-size: .72rem;
  margin-right: .35rem;
  margin-top: .35rem;
  background: rgba(255, 255, 255, .08);
  color: #ffffff;
}

.footer-social .social-btn:hover {
  color: #ffffff;
  border-color: rgba(226, 232, 240, .6);
  background: rgba(255, 255, 255, .15);
}

.footer-links a:hover,
.footer-contact-text a:hover {
  color: #93c5fd;
}

/* Errors */
.error-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 1.2rem;
  background: var(--m3-surface);
}

.error-card {
  width: min(560px, 100%);
  border-radius: var(--m3-radius-lg);
  background: var(--m3-surface-container-low);
  border: 1px solid var(--m3-outline-variant);
  box-shadow: var(--m3-shadow-2);
  padding: 1.5rem;
  text-align: center;
}

.error-chip {
  display: inline-flex;
  border-radius: 999px;
  padding: .24rem .68rem;
  border: 1px solid color-mix(in srgb, var(--m3-error) 38%, transparent);
  background: var(--m3-error-container);
  color: var(--m3-error);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.error-card h1 {
  margin: .8rem 0 .35rem;
  font-size: 1.8rem;
}

.error-card p {
  color: var(--m3-on-surface-variant);
  margin-bottom: 1rem;
}

.error-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .6rem;
}

.error-link-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .56rem .95rem;
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  background: transparent;
  color: var(--m3-on-surface);
  font-weight: 700;
  font-size: .86rem;
}

.error-link-secondary:hover {
  background: var(--m3-surface-container);
  color: var(--m3-primary);
}

/* Responsive */
@media (max-width: 1100px) {
  .container { width: min(1240px, calc(100% - 1.6rem)); }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-sidebar { flex-direction: row; flex-wrap: wrap; }
  .hero-side-item { width: calc(50% - .52rem); }
  .articles-grid,
  .articles-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .article-layout { grid-template-columns: 1fr; }
  .article-sidebar,
  .social-sidebar { display: none !important; }
}

@media (max-width: 760px) {
  .header-main-inner {
    flex-wrap: wrap;
    gap: .65rem;
  }
  .header-search {
    max-width: none;
    order: 3;
    width: 100%;
  }
  .main-nav {
    padding-bottom: .55rem;
  }
  .mobile-menu-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid var(--m3-outline-variant);
    width: 38px;
    height: 38px;
    color: var(--m3-on-surface-variant);
    margin-bottom: .4rem;
  }
  .nav-list {
    display: none;
    flex-direction: column;
    gap: .35rem;
    margin-top: .2rem;
  }
  .nav-list.open {
    display: flex;
  }
  .nav-link {
    border: 1px solid var(--m3-outline-variant);
    background: var(--m3-surface-container-low);
  }
  .articles-grid,
  .articles-grid-4,
  .pricing-grid,
  .form-row {
    grid-template-columns: 1fr;
  }
  .hero-side-item { width: 100%; }
  .search-page-form { border-radius: 16px; }
  .search-page-btn { border-radius: 12px; }
  .social-strip-mobile { display: flex !important; }
}

/* Header: Mobile Drawer + Main Row Layout */
.header-main-inner {
  display: flex;
  align-items: center;
  gap: .7rem;
}

.site-logo {
  margin-right: auto;
}

.header-main-actions {
  display: flex;
  align-items: center;
  gap: .55rem;
  margin-left: auto;
}

.header-hamburger-btn {
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  border: 1px solid var(--m3-outline-variant);
  background: #fff;
  color: var(--m3-on-surface);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
}

.header-hamburger-btn .header-hamburger-lines span {
  width: 18px;
  height: 2px;
  border-radius: 2px;
  background: currentColor;
}

.mobile-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(2, 6, 23, .72);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition);
  z-index: 360;
}

.mobile-drawer {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: min(286px, 82vw);
  background: #ffffff !important;
  opacity: 1;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-right: 1px solid var(--m3-outline-variant);
  box-shadow: var(--m3-shadow-3);
  transform: translateX(-105%);
  transition: transform var(--transition);
  z-index: 370;
  display: flex;
  flex-direction: column;
  isolation: isolate;
}

.mobile-drawer,
.mobile-drawer * {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.mobile-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .72rem .78rem;
  border-bottom: 1px solid var(--m3-outline-variant);
  background: #fff;
}

.mobile-drawer-header strong {
  font-size: .88rem;
  letter-spacing: .01em;
}

.mobile-drawer-close {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  border: 1px solid var(--m3-outline-variant);
  background: #fff;
  cursor: pointer;
  color: var(--m3-on-surface);
}

.mobile-drawer-nav {
  display: flex;
  flex-direction: column;
  padding: .38rem;
  gap: .18rem;
}

.mobile-drawer-link-featured {
  font-weight: 800;
}

.mobile-drawer-divider {
  height: 1px;
  margin: .14rem .22rem .24rem;
  background: color-mix(in srgb, var(--m3-outline-variant) 78%, transparent);
}

.mobile-drawer-link,
.mobile-drawer-action {
  display: block;
  border-radius: 8px;
  border: 1px solid transparent;
  padding: .52rem .58rem;
  font-size: .82rem;
  font-weight: 700;
  color: #1f2937;
  background: #fff;
  line-height: 1.25;
}

.mobile-drawer-link:hover,
.mobile-drawer-action:hover {
  border-color: var(--m3-outline-variant);
  background: #f5f7fc;
  color: #1d4ed8;
}

.mobile-drawer-footer {
  margin-top: auto;
  padding: .38rem;
  border-top: 1px solid var(--m3-outline-variant);
  display: grid;
  gap: .18rem;
  background: #fff;
}

.mobile-drawer-action-logout {
  color: #b91c1c;
}

.mobile-drawer-install {
  border-color: var(--m3-primary);
  color: var(--m3-primary);
  text-align: center;
  font-weight: 800;
}

body.mobile-menu-open {
  overflow: hidden;
  width: 100%;
}

body.mobile-menu-open .site-header {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.mobile-menu-open .mobile-drawer {
  transform: translateX(0);
}

body.mobile-menu-open .mobile-drawer-overlay {
  opacity: 1;
  pointer-events: auto;
}

@media (max-width: 760px) {
  .header-top-inner {
    justify-content: space-between;
  }

  .header-social {
    display: none;
  }

  .header-main {
    padding: .65rem 0;
  }

  .header-hamburger-btn {
    display: inline-flex;
  }

  .logo-text {
    font-size: 1.05rem;
  }

  .site-logo {
    padding: .45rem .8rem;
  }

  .header-main-actions {
    gap: .35rem;
  }

  .header-user-area .header-subscribe-btn {
    display: none;
  }

  .header-login-btn {
    padding: .34rem .7rem;
    font-size: .74rem;
  }

  .user-menu-name {
    display: none;
  }

  .main-nav {
    display: none;
  }

  .mobile-drawer {
    width: min(272px, 80vw);
  }
}

/* Single Typeface Across Entire Public UI */
body,
body * {
  font-family: var(--font-sans) !important;
}

/* Author profile + author edit */
.author-link,
.meta-author-link {
  color: inherit;
  text-decoration: none;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.author-link:hover,
.meta-author-link:hover {
  color: var(--m3-primary);
}

.author-main {
  padding: 1rem 0 2.2rem;
}

.author-profile-card,
.author-edit-card {
  background: var(--m3-surface-container-low);
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-lg);
  box-shadow: var(--m3-shadow-1);
  padding: 1.1rem;
}

.author-hero {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 1rem;
  align-items: start;
}

.author-avatar-lg {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  background: var(--m3-primary-container);
  border: 1px solid var(--m3-outline-variant);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.author-avatar-lg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.author-avatar-lg span {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--m3-primary);
}

.author-main-info {
  min-width: 0;
}

.author-badge-row {
  display: flex;
  gap: .55rem;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: .45rem;
}

.author-role-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .2rem .62rem;
  font-size: .72rem;
  font-weight: 700;
  background: var(--m3-primary-container);
  color: var(--m3-primary);
}

.author-edit-btn,
.author-edit-back {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  padding: .3rem .75rem;
  font-size: .75rem;
  font-weight: 700;
  color: var(--m3-on-surface-variant);
  background: var(--m3-surface);
}

.author-edit-btn:hover,
.author-edit-back:hover {
  border-color: color-mix(in srgb, var(--m3-primary) 40%, var(--m3-outline-variant));
  color: var(--m3-primary);
}

.author-name {
  font-size: clamp(1.25rem, 2.5vw, 1.9rem);
  line-height: 1.2;
  margin-bottom: .15rem;
  color: var(--m3-on-surface);
}

.author-username {
  font-size: .8rem;
  color: var(--m3-on-surface-variant);
  margin-bottom: .55rem;
}

.author-bio {
  color: var(--m3-on-surface);
  line-height: 1.7;
  white-space: pre-wrap;
}

.author-bio-muted {
  color: var(--m3-on-surface-variant);
}

.author-contact-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .7rem;
  margin-top: .95rem;
}

.author-contact-item {
  display: grid;
  gap: .2rem;
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-sm);
  padding: .68rem .78rem;
  background: var(--m3-surface);
}

.author-contact-item strong {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--m3-on-surface-variant);
}

.author-contact-item span {
  font-size: .86rem;
  color: var(--m3-on-surface);
  overflow-wrap: anywhere;
}

.author-contact-item:hover {
  border-color: color-mix(in srgb, var(--m3-primary) 36%, var(--m3-outline-variant));
}

.author-extra-info {
  margin-top: .8rem;
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-sm);
  padding: .8rem .9rem;
  background: var(--m3-surface);
}

.author-extra-info h2 {
  font-size: .85rem;
  margin-bottom: .35rem;
  color: var(--m3-on-surface);
}

.author-extra-info p {
  color: var(--m3-on-surface-variant);
  white-space: pre-wrap;
}

.author-articles-section {
  margin-top: 1rem;
}

.author-edit-main {
  padding: 1rem 0 2.2rem;
}

.author-edit-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .65rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.author-edit-head h1 {
  font-size: clamp(1.15rem, 2vw, 1.55rem);
  color: var(--m3-on-surface);
}

.author-edit-form .form-input,
.author-edit-form .form-textarea {
  background: var(--m3-surface);
}

.author-edit-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .85rem;
}

.author-edit-actions {
  display: flex;
  gap: .55rem;
  align-items: center;
  flex-wrap: wrap;
}

@media (max-width: 900px) {
  .author-contact-grid {
    grid-template-columns: 1fr;
  }

  .author-edit-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .author-hero {
    grid-template-columns: 1fr;
  }

  .author-avatar-lg {
    width: 72px;
    height: 72px;
  }
}

/* Search sidebar: keep fixed right column independent from results */
.search-page-shell {
  padding-top: 1rem;
  padding-bottom: 2.2rem;
}

.search-hero-inline {
  padding: 0 0 .95rem;
  margin-bottom: 0;
}

.search-layout {
  grid-template-columns: minmax(0, 1fr) 300px;
  column-gap: 1.05rem;
  row-gap: 0;
  align-items: start;
}

.search-layout > .article-col-wrap {
  min-width: 0;
}

.search-layout > .search-sidebar {
  position: sticky;
  top: var(--sticky-header-offset);
  align-self: start;
  margin-top: 0 !important;
  height: max-content;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.search-layout > .search-sidebar .sidebar-widget {
  margin-bottom: 0;
}

.search-layout .search-page-form {
  width: 100%;
  max-width: none;
}

.search-layout .search-page-form-autocomplete {
  width: 100%;
}

.search-layout .article-col-wrap > .empty-state {
  width: 100%;
  max-width: none;
  margin: .35rem 0 0;
}

/* Override global article sidebar collapsing for search page */
@media (max-width: 1100px) {
  .search-layout {
    grid-template-columns: minmax(0, 1fr) 300px !important;
  }

  .search-layout > .search-sidebar {
    display: flex !important;
  }
}

@media (max-width: 920px) {
  .search-layout {
    grid-template-columns: 1fr !important;
  }

  .search-layout > .search-sidebar {
    display: none !important;
  }
}

/* Mobile article social strip: full-width, clearly visible actions */
@media (max-width: 900px) {
  .social-strip-mobile {
    width: 100%;
    display: grid !important;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: .4rem;
    border-radius: var(--m3-radius-md);
    border: 1px solid var(--m3-outline-variant);
    background: #ffffff;
    padding: .45rem;
    margin: .7rem 0 1rem;
    box-shadow: var(--m3-shadow-1);
  }

  .social-strip-btn {
    width: 100%;
    height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    border: 1px solid var(--m3-outline-variant);
    background: #ffffff;
    color: var(--m3-on-surface);
    position: relative;
    padding: 0;
  }

  .social-strip-btn svg {
    width: 20px !important;
    height: 20px !important;
  }

  .social-strip-btn:hover,
  .social-strip-btn:active {
    background: var(--m3-primary-container);
    color: var(--m3-primary);
    border-color: color-mix(in srgb, var(--m3-primary) 35%, var(--m3-outline-variant));
  }

  .social-strip-btn.ss-heart.bookmarked {
    color: #c62828;
    border-color: color-mix(in srgb, #c62828 40%, var(--m3-outline-variant));
  }

  .ss-count {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    border-radius: 999px;
    background: #c62828;
    color: #fff;
    font-size: .64rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
  }
}

/* Category hero redesign (simple and clean) */
.category-hero {
  padding: .85rem 0 1.05rem !important;
  border: 0 !important;
  background: transparent !important;
}

.cat-hero-shell {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 1rem 1.25rem;
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-lg);
  background: var(--m3-surface-container-low);
  box-shadow: var(--m3-shadow-1);
  padding: 1rem 1.2rem;
}

.cat-hero-main {
  min-width: 0;
}

.cat-breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: .38rem;
  margin-bottom: .42rem;
  font-size: .73rem;
  color: var(--m3-on-surface-variant);
}

.cat-breadcrumb a {
  color: inherit;
}

.cat-breadcrumb a:hover {
  color: var(--m3-primary);
}

.cat-breadcrumb span:last-child {
  color: var(--m3-on-surface);
  font-weight: 600;
}

.cat-page-title {
  margin: 0;
  line-height: 1.14;
}

.cat-page-desc {
  max-width: 68ch;
  margin-top: .45rem;
  line-height: 1.56;
}

.cat-hero-meta {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  white-space: nowrap;
  border: 1px solid var(--m3-outline-variant);
  border-radius: 999px;
  background: var(--m3-surface);
  padding: .48rem .78rem;
  font-size: .78rem;
  font-weight: 600;
  color: var(--m3-on-surface-variant);
}

.cat-hero-meta strong {
  color: var(--m3-on-surface);
  font-size: .92rem;
}

.cat-hero-meta-sep {
  opacity: .55;
}

@media (max-width: 860px) {
  .cat-hero-shell {
    grid-template-columns: 1fr;
    align-items: start;
    padding: .95rem 1rem;
  }

  .cat-hero-meta {
    width: max-content;
    max-width: 100%;
    white-space: normal;
    flex-wrap: wrap;
  }
}

@media (max-width: 560px) {
  .cat-page-desc {
    font-size: .84rem;
  }

  .cat-hero-meta {
    width: 100%;
    border-radius: 12px;
  }

  .cat-hero-meta-sep {
    display: none;
  }
}

/* Header compact minimalist override */
.header-top {
  padding: .24rem 0 !important;
  font-size: .72rem !important;
}

.header-top-inner {
  min-height: 26px;
}

.header-date {
  font-size: .72rem;
  font-weight: 600;
}

.header-social {
  display: none !important;
}

.header-top-right {
  gap: .45rem !important;
}

.header-top-search-link {
  padding: .2rem .56rem;
  border-radius: 8px;
  font-size: .7rem;
  font-weight: 700;
}

.header-main {
  padding: .42rem 0 !important;
}

.header-main-inner {
  min-height: 44px;
  gap: .45rem !important;
}

.site-logo {
  padding: .3rem .62rem !important;
  border-radius: 10px;
}

.logo-text {
  font-size: 1rem !important;
  letter-spacing: -.01em;
}

.header-main-actions {
  gap: .4rem !important;
}

.header-user-area {
  gap: .3rem;
}

.header-login-btn,
.header-subscribe-btn,
.header-install-btn {
  padding: .3rem .62rem !important;
  font-size: .72rem !important;
}

.user-menu-btn {
  min-height: 34px;
  padding: .18rem .55rem .18rem .24rem !important;
  font-size: .74rem;
}

.user-avatar-img,
.user-avatar-initials {
  width: 20px;
  height: 20px;
}

.user-menu-name {
  max-width: 72px;
}

.main-nav {
  padding: .22rem 0 .32rem !important;
}

.main-nav .container {
  overflow: visible;
}

.nav-list {
  flex-wrap: nowrap !important;
  gap: .22rem !important;
  overflow: visible;
}

.nav-link {
  padding: .34rem .66rem !important;
  font-size: .74rem !important;
  font-weight: 700;
}

@media (max-width: 760px) {
  .header-top {
    display: block;
  }

  .header-main {
    padding: .48rem 0 !important;
  }

  .site-logo {
    padding: .34rem .62rem !important;
  }

  .logo-text {
    font-size: .96rem !important;
  }

  .header-hamburger-btn {
    width: 36px;
    height: 36px;
    border-radius: 9px;
  }

  .header-login-btn,
  .header-install-btn {
    padding: .3rem .58rem !important;
    font-size: .72rem !important;
  }
}

/* Header logos: day/night image support */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.site-logo--image {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.site-logo-picture {
  display: block;
  line-height: 0;
}

.site-logo-img {
  display: block;
  width: auto;
  height: 30px;
  max-width: min(260px, 48vw);
  object-fit: contain;
}

@media (max-width: 760px) {
  .site-logo--image {
    padding: 0 !important;
  }

  .site-logo-img {
    height: 24px;
    max-width: min(170px, 56vw);
  }
}

/* Homepage hero: align right column bottom with main card on desktop */
@media (min-width: 1101px) {
  .hero-grid {
    align-items: stretch !important;
  }

  .hero-main,
  .hero-main-link,
  .hero-sidebar {
    height: 100%;
  }

  .hero-sidebar {
    justify-content: flex-start;
    gap: .8rem;
  }

  .hero-sidebar .hero-side-item {
    flex: 1 1 0;
    min-height: 0;
  }
}

/* Homepage subscription CTA */
.subscription-cta-section {
  padding-top: .45rem !important;
}

.home-subscribe-cta {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 1rem 1.2rem;
  background: var(--m3-surface-container-low);
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-lg);
  box-shadow: var(--m3-shadow-1);
  padding: 1rem 1.2rem;
}

.home-subscribe-main {
  min-width: 0;
}

.home-subscribe-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, #d97706 40%, var(--m3-outline-variant));
  background: #fef3c7;
  color: #92400e;
  padding: .16rem .56rem;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .02em;
  text-transform: uppercase;
  margin-bottom: .4rem;
}

.home-subscribe-title {
  margin: 0;
  font-size: clamp(1.12rem, 2vw, 1.44rem);
  line-height: 1.2;
  color: var(--m3-on-surface);
}

.home-subscribe-text {
  margin-top: .35rem;
  color: var(--m3-on-surface-variant);
  font-size: .86rem;
}

.home-subscribe-plans {
  display: grid;
  gap: .45rem;
  min-width: min(340px, 100%);
}

.home-subscribe-plan {
  display: grid;
  gap: .12rem;
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-radius-sm);
  background: var(--m3-surface);
  padding: .52rem .72rem;
  line-height: 1.35;
}

.home-subscribe-plan strong {
  font-size: .8rem;
  color: var(--m3-on-surface);
}

.home-subscribe-plan span {
  font-size: .76rem;
  color: var(--m3-on-surface-variant);
}

.home-subscribe-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #d97706;
  color: #fff;
  border: 0;
  font-size: .82rem;
  font-weight: 700;
  padding: .62rem 1.05rem;
  white-space: nowrap;
}

.home-subscribe-btn:hover {
  background: #b45309;
}

/* Header VIP badge */
.header-vip-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: .12rem .42rem;
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .02em;
  color: #7c4a03;
  background: #fcd34d;
  border: 1px solid #fbbf24;
  line-height: 1;
}

.mobile-drawer-vip {
  display: block;
  margin: 0 .14rem .28rem;
  border: 1px solid #fbbf24;
  border-radius: 8px;
  background: #fef3c7;
  color: #7c4a03;
  font-size: .72rem;
  font-weight: 700;
  padding: .46rem .58rem;
}

@media (max-width: 1020px) {
  .home-subscribe-cta {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .home-subscribe-plans {
    min-width: 0;
    width: 100%;
  }

  .home-subscribe-btn {
    width: 100%;
  }
}

/* Subscribe page: payment info + FAQ polish */
.site-main .payment-methods-info {
  margin: .9rem 0 1.1rem;
  padding: .95rem 1.1rem;
  background: var(--m3-surface-container-low);
}

.site-main .payment-methods-info > p {
  margin: 0 0 .62rem;
  font-size: .9rem;
  font-weight: 700;
  color: var(--m3-on-surface);
}

.site-main .pm-logos {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.site-main .pm-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: .24rem .72rem;
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface-container);
  color: var(--m3-on-surface-variant);
  font-size: .74rem;
  font-weight: 700;
}

.site-main .pm-paysera,
.site-main .pm-card {
  background: color-mix(in srgb, var(--m3-primary-container) 72%, #fff);
  color: var(--m3-primary);
  border-color: color-mix(in srgb, var(--m3-primary) 26%, var(--m3-outline-variant));
}

.site-main .subscribe-faq {
  margin: 0 0 1.7rem;
  padding: 1.05rem 1.1rem 1.15rem;
  background: var(--m3-surface-container-low);
}

.site-main .faq-title {
  margin: 0 0 .85rem;
  font-size: clamp(1.22rem, 2vw, 1.62rem);
  line-height: 1.2;
  color: var(--m3-on-surface);
}

.site-main .faq-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
}

.site-main .faq-item {
  margin: 0;
  padding: .92rem 1rem;
  border-radius: var(--m3-radius-sm);
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface);
  box-shadow: none;
}

.site-main .faq-item h4 {
  margin: 0 0 .45rem;
  font-size: .98rem;
  line-height: 1.35;
  color: var(--m3-on-surface);
}

.site-main .faq-item p {
  margin: 0;
  font-size: .9rem;
  line-height: 1.58;
  color: var(--m3-on-surface-variant);
}

@media (max-width: 900px) {
  .site-main .faq-grid {
    grid-template-columns: 1fr;
  }

  .site-main .subscribe-faq,
  .site-main .payment-methods-info {
    padding: .88rem .85rem .94rem;
  }
}

/* ===================== HEADER SIMPLIFIED REBUILD ===================== */
.main-nav {
  display: none !important;
}

.header-top {
  border: 0 !important;
  box-shadow: none !important;
  max-height: 56px;
  overflow: hidden;
  opacity: 1;
  transition: max-height .24s ease, opacity .18s ease, padding .18s ease, border-color .18s ease;
}

body.topbar-hidden .header-top {
  max-height: 0;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  opacity: 0;
  border: 0 !important;
  pointer-events: none;
}

.header-date {
  font-size: .72rem !important;
}

.header-top-right {
  align-items: center !important;
}

.header-top-search-link {
  border: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
  color: var(--m3-on-surface-variant) !important;
  font-size: .78rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 20px;
  line-height: 1.2;
  vertical-align: middle;
  white-space: nowrap;
}

.header-top-search-link:hover {
  color: var(--m3-primary) !important;
}

.header-top-install-link {
  border: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
  color: var(--m3-on-surface-variant) !important;
  font-size: .74rem !important;
  font-weight: 600 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 20px;
  line-height: 1.2;
  vertical-align: middle;
  white-space: nowrap;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  font-family: inherit;
}

.header-top-install-link:hover {
  color: var(--m3-primary) !important;
}

.header-main {
  padding: .55rem 0 .65rem !important;
}

.header-main-inner {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: .7rem !important;
  min-height: 54px;
}

.header-main-left,
.header-main-right {
  display: flex;
  align-items: center;
}

.header-main-left {
  justify-content: flex-start;
}

.header-main-right {
  justify-content: flex-end;
}

.header-main-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.site-logo {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.logo-text {
  font-size: 1.06rem !important;
}

.site-logo-img {
  height: 34px !important;
  max-width: min(290px, 42vw);
}

.header-hamburger-btn {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  flex-direction: row !important;
  gap: .45rem;
  width: auto;
  min-width: 108px;
  height: 38px;
  padding: 0 .72rem;
  border-radius: 12px;
  border: 1px solid var(--m3-outline-variant);
  background: var(--m3-surface-container-low);
  color: var(--m3-on-surface);
  font-size: .8rem;
  font-weight: 700;
  line-height: 1;
}

.header-hamburger-lines {
  display: inline-flex;
  flex-direction: column;
  gap: 3px;
}

.header-hamburger-lines span {
  width: 14px !important;
  height: 2px !important;
  border-radius: 2px;
  background: currentColor !important;
}

.header-hamburger-label {
  display: inline-block;
  line-height: 1;
  font-size: .84rem;
  font-weight: 700;
  letter-spacing: .01em;
  width: auto !important;
  height: auto !important;
  background: transparent !important;
}

.header-user-area {
  gap: .45rem !important;
}

.header-login-btn,
.header-register-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .36rem;
  min-height: 38px;
  padding: .4rem .8rem !important;
  border-radius: 999px;
  font-size: .78rem !important;
  font-weight: 700;
  letter-spacing: .01em;
  text-transform: none !important;
  border: 1px solid var(--m3-outline-variant);
  background: #fff;
  color: var(--m3-on-surface);
}

.header-login-btn:hover,
.header-register-btn:hover {
  color: var(--m3-primary);
  border-color: color-mix(in srgb, var(--m3-primary) 35%, var(--m3-outline-variant));
  background: var(--m3-primary-container);
}

.header-register-btn {
  background: var(--m3-primary);
  color: var(--m3-on-primary);
  border-color: var(--m3-primary);
}

.header-register-btn:hover {
  color: var(--m3-on-primary);
  background: color-mix(in srgb, var(--m3-primary) 92%, #000);
}

.header-login-icon {
  flex-shrink: 0;
}

.user-menu {
  position: relative;
}

.user-menu-btn {
  display: inline-flex;
  align-items: center;
  gap: .44rem;
  min-height: 38px;
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  background: #fff !important;
  color: var(--m3-on-surface) !important;
  padding: .26rem .8rem .26rem .32rem !important;
  font-size: .79rem;
  font-weight: 700;
}

.user-menu-btn:hover {
  border-color: color-mix(in srgb, var(--m3-primary) 35%, var(--m3-outline-variant));
  background: var(--m3-primary-container) !important;
}

.user-menu-name {
  max-width: 128px !important;
}

.user-menu-caret {
  font-size: .62rem;
  color: var(--m3-on-surface-variant);
}

.user-avatar-img,
.user-avatar-initials {
  width: 24px;
  height: 24px;
}

.user-dropdown {
  top: calc(100% + 8px);
  right: 0;
  min-width: 220px;
  border: 1px solid var(--m3-outline-variant);
  border-radius: 14px;
  box-shadow: var(--m3-shadow-2);
  background: #fff;
}

.dropdown-item {
  padding: .62rem .92rem;
  font-size: .82rem;
  font-weight: 600;
}

.dropdown-item:hover {
  background: var(--m3-surface-container);
}

.dropdown-premium-badge {
  border-bottom: 1px solid var(--m3-outline-variant);
}

@media (max-width: 900px) {
  .header-main-inner {
    grid-template-columns: auto 1fr auto;
  }

  .header-hamburger-btn {
    width: 38px;
    min-width: 38px;
    height: 38px;
    padding: 0;
    border-radius: 10px;
    gap: 0;
  }

  .header-hamburger-label {
    display: none;
  }

  .header-hamburger-lines span {
    width: 16px !important;
  }

  .site-logo-img {
    height: 28px !important;
    max-width: min(210px, 52vw);
  }

  .header-register-btn {
    display: none;
  }

  .header-login-btn span {
    display: none;
  }

  .header-login-btn {
    width: 38px;
    padding: 0 !important;
    gap: 0;
  }

  .user-menu-name {
    display: none;
  }
}

/* Links: no underline globally, except article content text */
a,
a:hover,
a:focus {
  text-decoration: none !important;
}

.article-content a,
.article-content a:hover,
.article-content a:focus {
  text-decoration: underline !important;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

/* ===================== FOOTER 3-SECTIONS ===================== */
.site-footer {
  margin-top: 1.8rem;
  background: #0f172a;
  border-top: 0;
  padding: 1.2rem 0 .95rem;
}

.site-footer .footer-sections {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, .95fr);
  gap: .95rem;
  align-items: start;
}

.site-footer .footer-section {
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(226, 232, 240, .16);
  border-radius: 14px;
  padding: .9rem .92rem;
}

.site-footer .footer-heading {
  margin-bottom: .62rem;
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #e2e8f0;
}

.footer-newsletter-text {
  font-size: .81rem;
  line-height: 1.45;
  color: rgba(226, 232, 240, .88);
  margin-bottom: .62rem;
}

.footer-newsletter-form {
  display: grid;
  gap: .55rem;
}

.footer-newsletter-input {
  width: 100%;
  height: 40px;
  border-radius: 10px;
  border: 1px solid rgba(148, 163, 184, .42);
  background: rgba(15, 23, 42, .48);
  color: #f8fafc;
  padding: 0 .78rem;
  font-size: .84rem;
}

.footer-newsletter-input::placeholder {
  color: rgba(203, 213, 225, .76);
}

.footer-newsletter-input:focus {
  outline: none;
  border-color: #93c5fd;
  box-shadow: 0 0 0 3px rgba(147, 197, 253, .16);
}

.footer-newsletter-consent {
  display: flex;
  align-items: flex-start;
  gap: .45rem;
  font-size: .77rem;
  line-height: 1.35;
  color: rgba(226, 232, 240, .95);
}

.footer-newsletter-consent input[type="checkbox"] {
  width: 15px;
  height: 15px;
  margin-top: 1px;
  accent-color: #3b82f6;
}

.footer-newsletter-submit {
  height: 40px;
  border: 0;
  border-radius: 10px;
  background: #2563eb;
  color: #ffffff;
  font-size: .84rem;
  font-weight: 700;
  cursor: pointer;
  transition: filter var(--transition), transform var(--transition);
}

.footer-newsletter-submit:hover {
  filter: brightness(.96);
  transform: translateY(-1px);
}

.footer-newsletter-submit:disabled {
  opacity: .72;
  cursor: wait;
  transform: none;
}

.footer-newsletter-status {
  min-height: 1.1rem;
  margin-top: .52rem;
  font-size: .76rem;
  color: rgba(226, 232, 240, .82);
}

.footer-newsletter-status.success {
  color: #86efac;
}

.footer-newsletter-status.error {
  color: #fca5a5;
}

.site-footer .footer-links {
  list-style: none;
  display: grid;
  gap: .44rem;
}

.site-footer .footer-links a {
  display: inline-block;
  font-size: .84rem;
  color: rgba(241, 245, 249, .94);
  line-height: 1.35;
}

.site-footer .footer-links a:hover {
  color: #93c5fd;
}

.site-footer .footer-empty {
  font-size: .8rem;
  color: rgba(203, 213, 225, .85);
}

.site-footer .footer-social-section .e-social-holder {
  display: flex;
  flex-wrap: wrap;
  gap: .52rem;
}

.site-footer .footer-social-section .e-social-holder a {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .22);
  background: rgba(255, 255, 255, .08);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff !important;
  transition: transform var(--transition), background var(--transition), border-color var(--transition);
}

.site-footer .footer-social-section .e-social-holder a:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, .2);
  border-color: rgba(255, 255, 255, .44);
}

.site-footer .footer-social-section .e-social-holder svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.site-footer .footer-bottom {
  margin-top: .88rem;
  padding-top: .78rem;
  border-top: 1px solid rgba(226, 232, 240, .16);
  text-align: center;
  color: rgba(226, 232, 240, .9);
  font-size: .78rem;
  opacity: 1;
}

@media (max-width: 980px) {
  .site-footer .footer-sections {
    grid-template-columns: 1fr 1fr;
  }

  .site-footer .footer-newsletter {
    grid-column: 1 / -1;
  }
}

@media (max-width: 680px) {
  .site-footer .footer-sections {
    grid-template-columns: 1fr;
  }

  .site-footer .footer-newsletter {
    grid-column: auto;
  }
}

/* ===================== AUTH INPUT WIDTH FIX ===================== */
.auth-form .form-group,
.auth-form .password-wrap,
.auth-form .form-input {
  width: 100%;
}

.auth-form .password-wrap .form-input {
  padding-right: 2.8rem;
}

/* ===================== THEME TOGGLE + DARK THEME ===================== */
.site-logo-img-dark {
  display: none;
}

body.theme-dark .site-logo-img-light {
  display: none;
}

body.theme-dark .site-logo-img-dark {
  display: block;
}

.header-theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  min-width: 38px;
  height: 38px;
  padding: 0;
  border-radius: 10px;
  border: 1px solid var(--m3-outline-variant);
  background: #fff;
  color: var(--m3-on-surface);
  font-size: .86rem;
  line-height: 1;
  cursor: pointer;
}

.header-theme-toggle:hover {
  border-color: color-mix(in srgb, var(--m3-primary) 35%, var(--m3-outline-variant));
  background: var(--m3-primary-container);
  color: var(--m3-primary);
}

.header-theme-toggle-icon {
  font-size: .92rem;
  line-height: 1;
}

@media (max-width: 900px) {
  .header-theme-toggle { width: 38px; min-width: 38px; }
}

body.theme-dark {
  --m3-primary: #9ec3ff;
  --m3-on-primary: #081226;
  --m3-primary-container: #1c2a43;
  --m3-on-primary-container: #d7e6ff;
  --m3-secondary: #9ec3ff;
  --m3-secondary-container: #1c2a43;
  --m3-tertiary: #f1c168;
  --m3-tertiary-container: #3a2f1a;
  --m3-surface: #0b1220;
  --m3-surface-container-low: #111a2b;
  --m3-surface-container: #162236;
  --m3-surface-container-high: #1b2940;
  --m3-surface-container-highest: #22314a;
  --m3-outline: #5c6f8d;
  --m3-outline-variant: #31435d;
  --m3-on-surface: #e6edf8;
  --m3-on-surface-variant: #afbed3;
  --m3-error: #ffb4ab;
  --m3-error-container: #51201a;
  --m3-success: #88e0a6;
  --m3-warning: #f4c676;
  --bg: #0b1220;
  --bg2: #111a2b;
  --bg3: #162236;
  --text: #e6edf8;
  --text-muted: #bdcbe0;
  --text-light: #8fa1bf;
  --border: #32445f;
  --border-light: #263750;
  --dark: #e6edf8;
  --dark2: #08111f;
  --primary: #9ec3ff;
  --primary-dark: #7ca7f3;
  --primary-light: #b8d4ff;
  background:
    radial-gradient(circle at 12% -6%, rgba(38, 72, 121, .34) 0, transparent 42%),
    radial-gradient(circle at 92% 0%, rgba(30, 60, 104, .26) 0, transparent 36%),
    var(--m3-surface);
  color: var(--m3-on-surface);
}

body.theme-dark .site-header {
  background: color-mix(in srgb, #0f1a2c 94%, #000 6%);
  border-bottom-color: var(--m3-outline-variant);
}

body.theme-dark .header-top {
  border-bottom-color: var(--m3-outline-variant) !important;
  color: var(--m3-on-surface-variant);
}

body.theme-dark .header-top-search-link,
body.theme-dark .header-top-install-link,
body.theme-dark .header-hamburger-btn,
body.theme-dark .header-theme-toggle,
body.theme-dark .header-login-btn,
body.theme-dark .user-menu-btn {
  background: var(--m3-surface-container-low) !important;
  color: var(--m3-on-surface) !important;
  border-color: var(--m3-outline-variant) !important;
}

body.theme-dark .header-register-btn {
  background: var(--m3-primary) !important;
  color: var(--m3-on-primary) !important;
  border-color: var(--m3-primary) !important;
}

body.theme-dark .header-top-search-link:hover,
body.theme-dark .header-top-install-link:hover,
body.theme-dark .header-hamburger-btn:hover,
body.theme-dark .header-theme-toggle:hover,
body.theme-dark .header-login-btn:hover,
body.theme-dark .user-menu-btn:hover {
  background: var(--m3-primary-container) !important;
  color: var(--m3-primary) !important;
}

body.theme-dark .header-register-btn:hover {
  filter: brightness(.94);
  color: var(--m3-on-primary) !important;
}

body.theme-dark .user-dropdown {
  background: var(--m3-surface-container-low);
  border-color: var(--m3-outline-variant);
}

body.theme-dark .dropdown-item:hover {
  background: var(--m3-surface-container);
}

body.theme-dark .site-footer {
  background: #08111f;
}

body.theme-dark .mobile-drawer {
  background: var(--m3-surface-container-low) !important;
  border-right-color: var(--m3-outline-variant);
}

body.theme-dark .mobile-drawer-header,
body.theme-dark .mobile-drawer-footer,
body.theme-dark .mobile-drawer-link,
body.theme-dark .mobile-drawer-action,
body.theme-dark .mobile-drawer-close {
  background: var(--m3-surface-container-low);
  color: var(--m3-on-surface);
  border-color: var(--m3-outline-variant);
}

body.theme-dark .mobile-drawer-link:hover,
body.theme-dark .mobile-drawer-action:hover {
  background: var(--m3-surface-container);
  color: var(--m3-primary);
}

body.theme-dark .home-news-card {
  background: var(--m3-surface-container-low);
  border: 1px solid color-mix(in srgb, var(--m3-outline-variant) 86%, transparent);
}

body.theme-dark .home-news-card-image-link {
  background: var(--m3-surface-container);
}

body.theme-dark .home-news-card-meta,
body.theme-dark .home-news-card-action {
  color: var(--m3-on-surface-variant);
}

/* ===================== HOMEPAGE MAGAZINE REMODEL ===================== */
.homepage-latest-section .section-header {
  margin-bottom: .95rem;
}

.homepage-latest-section .section-title {
  font-size: clamp(1.16rem, 2vw, 1.5rem);
}

.hero-grid--single {
  grid-template-columns: 1fr !important;
}

.latest-feed-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .95rem;
  margin-top: .95rem;
}

.latest-mini-card .card-image-link {
  aspect-ratio: 16 / 10;
}

.category-section--magazine .section-header {
  margin-bottom: .95rem;
}

.magazine-layout {
  display: grid;
  gap: .9rem;
}

.magazine-layout .slot-lead { grid-area: lead; }
.magazine-layout .slot-2 { grid-area: s2; }
.magazine-layout .slot-3 { grid-area: s3; }
.magazine-layout .slot-4 { grid-area: s4; }
.magazine-layout .slot-5 { grid-area: s5; }

.magazine-card {
  min-width: 0;
}

.magazine-card-lead .card-image-link {
  aspect-ratio: 16 / 9;
}

.magazine-card-compact .card-image-link {
  aspect-ratio: 16 / 10;
}

.magazine-card-compact .card-body {
  padding: .78rem .8rem .84rem;
}

.magazine-card-compact .card-meta {
  padding-top: .4rem;
}

.magazine-layout-a {
  grid-template-columns: minmax(0, 1.65fr) minmax(0, 1fr);
  grid-template-areas:
    "lead s2"
    "lead s3"
    "lead s4"
    "lead s5";
}

.magazine-layout-a .magazine-card-compact {
  display: grid;
  grid-template-columns: 114px 1fr;
}

.magazine-layout-a .magazine-card-compact .card-image-link {
  aspect-ratio: auto;
  height: 100%;
  min-height: 92px;
  border-bottom: 0;
  border-right: 1px solid var(--m3-outline-variant);
}

.magazine-layout-a .magazine-card-compact .card-body {
  padding: .62rem .74rem;
}

.magazine-layout-a .magazine-card-compact .card-title {
  font-size: .88rem;
  line-height: 1.35;
}

.magazine-layout-a .magazine-card-compact .card-meta {
  padding-top: .18rem;
  border-top: 0;
}

.magazine-layout-b {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-areas:
    "lead lead s2"
    "s3 s4 s5";
}

.magazine-layout-c {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-areas:
    "lead lead s2 s3"
    "lead lead s4 s5";
}

.magazine-layout-d {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-areas:
    "lead s2"
    "s3 s4"
    "s5 s5";
}

.magazine-layout-d .slot-5 {
  display: grid;
  grid-template-columns: 140px 1fr;
}

.magazine-layout-d .slot-5 .card-image-link {
  aspect-ratio: auto;
  height: 100%;
  min-height: 88px;
  border-bottom: 0;
  border-right: 1px solid var(--m3-outline-variant);
}

.magazine-layout-d .slot-5 .card-body {
  padding: .66rem .78rem;
}

@media (max-width: 1200px) {
  .latest-feed-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .magazine-layout {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "lead lead"
      "s2 s3"
      "s4 s5";
  }

  .magazine-layout-a .magazine-card-compact,
  .magazine-layout-d .slot-5 {
    display: block;
  }

  .magazine-layout-a .magazine-card-compact .card-image-link,
  .magazine-layout-d .slot-5 .card-image-link {
    aspect-ratio: 16 / 10;
    min-height: 0;
    border-right: 0;
    border-bottom: 1px solid var(--m3-outline-variant);
  }

  .magazine-layout-a .magazine-card-compact .card-meta,
  .magazine-layout-d .slot-5 .card-meta {
    border-top: 1px solid var(--m3-outline-variant);
    padding-top: .4rem;
  }
}

@media (max-width: 760px) {
  .latest-feed-grid {
    grid-template-columns: 1fr;
  }

  .magazine-layout {
    grid-template-columns: 1fr;
    grid-template-areas:
      "lead"
      "s2"
      "s3"
      "s4"
      "s5";
  }

  .magazine-card-compact .card-image-link {
    aspect-ratio: 16 / 9;
  }
}

/* ===================== HOMEPAGE TILES (B1 STYLE) ===================== */
.home-magazine-main {
  background: transparent;
}

.home-feed-section {
  padding: .95rem 0 1.35rem;
  background: transparent;
}

.home-feed-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  margin-bottom: .68rem;
}

.home-feed-kicker {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .8rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--m3-on-surface);
}

.home-feed-kicker::before {
  content: '';
  display: inline-block;
  width: 30px;
  height: 3px;
  border-radius: 99px;
  background: #dc2626;
}

.home-feed-kicker a {
  color: inherit;
}

.home-feed-more {
  font-size: .75rem;
  font-weight: 700;
  color: var(--m3-on-surface-variant);
}

.home-feed-more:hover {
  color: var(--m3-primary);
}

.home-tiles {
  display: grid;
  gap: .5rem;
}

.home-tiles-a {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-template-areas:
    "lead lead lead lead lead lead side side side side side side"
    "small1 small1 small1 small1 small2 small2 small2 small2 small3 small3 small3 small3";
}

.home-tiles-b {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-template-areas:
    "lead lead lead lead lead lead lead lead top top top top"
    "lead lead lead lead lead lead lead lead mid mid mid mid"
    "bottom1 bottom1 bottom1 bottom1 bottom1 bottom1 bottom2 bottom2 bottom2 bottom2 bottom2 bottom2";
}

.home-tile {
  min-width: 0;
  background: var(--m3-surface-container-low);
  border: 1px solid var(--m3-outline-variant);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: none;
  display: flex;
  flex-direction: column;
}

.home-tile.tile-lead { grid-area: lead; }
.home-tile.tile-side { grid-area: side; }
.home-tile.tile-small-1 { grid-area: small1; }
.home-tile.tile-small-2 { grid-area: small2; }
.home-tile.tile-small-3 { grid-area: small3; }
.home-tile.tile-top { grid-area: top; }
.home-tile.tile-mid { grid-area: mid; }
.home-tile.tile-bottom-1 { grid-area: bottom1; }
.home-tile.tile-bottom-2 { grid-area: bottom2; }

/* Kai kategorijoje mažiau nei 5 straipsniai, pereiname į saugų grid be tuščių tarpų */
.home-tiles-count-1,
.home-tiles-count-2,
.home-tiles-count-3,
.home-tiles-count-4 {
  grid-template-areas: none !important;
}

.home-tiles-count-1 .home-tile,
.home-tiles-count-2 .home-tile,
.home-tiles-count-3 .home-tile,
.home-tiles-count-4 .home-tile {
  grid-area: auto !important;
}

.home-tiles-count-1 {
  grid-template-columns: 1fr !important;
}

.home-tiles-count-2,
.home-tiles-count-3,
.home-tiles-count-4 {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.home-tiles-count-3 .home-tile:first-child {
  grid-column: 1 / -1;
}

/* Gyvenimas + Auto: visada laikyti "Naujausi" asimetrinį šabloną */
.home-tiles-force-latest.home-tiles-count-1,
.home-tiles-force-latest.home-tiles-count-2,
.home-tiles-force-latest.home-tiles-count-3,
.home-tiles-force-latest.home-tiles-count-4 {
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  grid-template-areas: none !important;
}

.home-tiles-force-latest.home-tiles-count-1 .home-tile,
.home-tiles-force-latest.home-tiles-count-2 .home-tile,
.home-tiles-force-latest.home-tiles-count-3 .home-tile,
.home-tiles-force-latest.home-tiles-count-4 .home-tile {
  grid-area: auto !important;
}

.home-tiles-force-latest.home-tiles-count-1 .home-tile:nth-child(1) {
  grid-column: 1 / -1 !important;
}

.home-tiles-force-latest.home-tiles-count-2 .home-tile:nth-child(1) {
  grid-column: span 8 !important;
}
.home-tiles-force-latest.home-tiles-count-2 .home-tile:nth-child(2) {
  grid-column: span 4 !important;
}

.home-tiles-force-latest.home-tiles-count-3 .home-tile:nth-child(1) {
  grid-column: span 8 !important;
}
.home-tiles-force-latest.home-tiles-count-3 .home-tile:nth-child(2) {
  grid-column: span 4 !important;
}
.home-tiles-force-latest.home-tiles-count-3 .home-tile:nth-child(3) {
  grid-column: 1 / -1 !important;
}

.home-tiles-force-latest.home-tiles-count-4 .home-tile:nth-child(1) {
  grid-column: span 8 !important;
}
.home-tiles-force-latest.home-tiles-count-4 .home-tile:nth-child(2) {
  grid-column: span 4 !important;
}
.home-tiles-force-latest.home-tiles-count-4 .home-tile:nth-child(3),
.home-tiles-force-latest.home-tiles-count-4 .home-tile:nth-child(4) {
  grid-column: span 6 !important;
}

.home-tile-image-link {
  display: block;
  aspect-ratio: 16 / 9;
  background: #d6deea;
  overflow: hidden;
  flex-shrink: 0;
}

.home-tile-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.home-tile-image-placeholder {
  background: linear-gradient(130deg, #dbe8f8, #c9d7eb);
}

.home-tile-body {
  padding: .42rem .5rem .45rem;
  display: flex;
  flex-direction: column;
  gap: .22rem;
  flex: 1;
  min-height: 94px;
}

.home-tile-title {
  margin: 0;
  font-size: .77rem;
  line-height: 1.3;
  font-weight: 700;
  color: var(--m3-on-surface);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.home-tile-title-lg {
  font-size: .9rem;
}

.home-tile-title a {
  color: inherit;
}

.home-tile-meta {
  margin-top: .2rem;
  font-size: .68rem;
  color: var(--m3-on-surface-variant);
}

.home-tile-excerpt {
  margin-top: .3rem;
  font-size: .75rem;
  line-height: 1.45;
  color: var(--m3-on-surface-variant);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}

.home-tile.tile-lead .home-tile-excerpt {
  -webkit-line-clamp: 8;
}

.home-tile-excerpt-long {
  -webkit-line-clamp: 12;
}

.home-tile-actions {
  margin-top: auto;
  padding-top: .34rem;
  border-top: 1px solid var(--m3-outline-variant);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .42rem;
}

.home-tile.tile-lead .home-tile-actions {
  margin-top: .45rem;
}

.home-tile-action {
  display: inline-flex;
  align-items: center;
  gap: .28rem;
  font-size: .72rem;
  font-weight: 600;
  line-height: 1;
  color: var(--m3-on-surface-variant);
  background: var(--m3-surface);
  border: 1px solid var(--m3-outline-variant);
  border-radius: 999px;
  min-height: 30px;
  padding: 0 .52rem;
  transition: color var(--transition), border-color var(--transition), background var(--transition);
}

.home-tile-action:hover {
  color: var(--m3-primary);
  border-color: color-mix(in srgb, var(--m3-primary) 35%, var(--m3-outline-variant));
  background: var(--m3-surface-container);
}

.home-tile-action svg {
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
  display: block;
}

.home-tile-bookmark {
  cursor: pointer;
  width: 30px;
  min-width: 30px;
  justify-content: center;
  padding: 0;
}

.home-tile-bookmark.is-bookmarked {
  color: #dc2626;
  border-color: #fca5a5;
  background: #fee2e2;
}

.home-tile-bookmark svg {
  width: 17px;
  height: 17px;
  flex-basis: 17px;
}

@media (max-width: 1100px) {
  .home-tiles-a {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "lead lead"
      "side side"
      "small1 small2"
      "small3 small3";
  }

  .home-tiles-b {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "lead lead"
      "top top"
      "mid bottom1"
      "bottom2 bottom2";
  }

  .home-feed-section {
    padding: .9rem 0 1.2rem;
  }

  .home-tiles-count-1 {
    grid-template-columns: 1fr !important;
  }

  .home-tiles-count-2,
  .home-tiles-count-3,
  .home-tiles-count-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .home-tiles-count-1 .home-tile,
  .home-tiles-count-2 .home-tile,
  .home-tiles-count-3 .home-tile,
  .home-tiles-count-4 .home-tile {
    grid-column: auto !important;
  }

  .home-tiles-count-3 .home-tile:first-child {
    grid-column: 1 / -1 !important;
  }

  .home-tiles-force-latest.home-tiles-count-1,
  .home-tiles-force-latest.home-tiles-count-2,
  .home-tiles-force-latest.home-tiles-count-3,
  .home-tiles-force-latest.home-tiles-count-4,
  .home-tiles-force-latest.home-tiles-count-5 {
    grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
    grid-template-areas: none !important;
  }

  .home-tiles-force-latest.home-tiles-count-1 .home-tile,
  .home-tiles-force-latest.home-tiles-count-2 .home-tile,
  .home-tiles-force-latest.home-tiles-count-3 .home-tile,
  .home-tiles-force-latest.home-tiles-count-4 .home-tile,
  .home-tiles-force-latest.home-tiles-count-5 .home-tile {
    grid-area: auto !important;
    grid-column: auto !important;
  }

  .home-tiles-force-latest.home-tiles-count-1 .home-tile:nth-child(1) {
    grid-column: 1 / -1 !important;
  }

  .home-tiles-force-latest.home-tiles-count-2 .home-tile:nth-child(1),
  .home-tiles-force-latest.home-tiles-count-2 .home-tile:nth-child(2) {
    grid-column: span 6 !important;
  }

  .home-tiles-force-latest.home-tiles-count-3 .home-tile:nth-child(1),
  .home-tiles-force-latest.home-tiles-count-3 .home-tile:nth-child(2) {
    grid-column: span 6 !important;
  }

  .home-tiles-force-latest.home-tiles-count-3 .home-tile:nth-child(3) {
    grid-column: 1 / -1 !important;
  }

  .home-tiles-force-latest.home-tiles-count-4 .home-tile:nth-child(1),
  .home-tiles-force-latest.home-tiles-count-4 .home-tile:nth-child(2) {
    grid-column: span 6 !important;
  }

  .home-tiles-force-latest.home-tiles-count-4 .home-tile:nth-child(3),
  .home-tiles-force-latest.home-tiles-count-4 .home-tile:nth-child(4) {
    grid-column: span 6 !important;
  }

  .home-tiles-force-latest.home-tiles-count-5 .home-tile:nth-child(1),
  .home-tiles-force-latest.home-tiles-count-5 .home-tile:nth-child(2) {
    grid-column: span 6 !important;
  }

  .home-tiles-force-latest.home-tiles-count-5 .home-tile:nth-child(3),
  .home-tiles-force-latest.home-tiles-count-5 .home-tile:nth-child(4),
  .home-tiles-force-latest.home-tiles-count-5 .home-tile:nth-child(5) {
    grid-column: span 4 !important;
  }
}

@media (max-width: 760px) {
  .home-tiles {
    grid-template-columns: 1fr;
  }

  .home-tiles-a,
  .home-tiles-b {
    grid-template-areas: none;
  }

  .home-tiles .home-tile,
  .home-tiles-count-1 .home-tile,
  .home-tiles-count-2 .home-tile,
  .home-tiles-count-3 .home-tile,
  .home-tiles-count-4 .home-tile {
    grid-area: auto !important;
    grid-column: 1 / -1 !important;
  }

  .home-tile-title {
    font-size: .82rem;
  }

  .home-tile-title-lg {
    font-size: .94rem;
  }

  .home-tile-action {
    min-height: 32px;
    font-size: .74rem;
  }

  .home-tile-action svg {
    width: 17px;
    height: 17px;
    flex-basis: 17px;
  }
}

/* ===================== HOMEPAGE MAGAZINE FINAL LAYOUT ===================== */
.home-magazine-main {
  background: transparent;
}

.home-feed-section {
  padding: .8rem 0 1.06rem;
  background: transparent;
}

.home-feed-head {
  margin-bottom: .56rem;
}

.home-feed-kicker {
  font-size: .76rem;
  letter-spacing: .025em;
}

.home-feed-kicker::before {
  width: 18px;
  height: 2px;
  border-radius: 99px;
  background: var(--m3-primary);
}

.home-feed-more {
  font-size: .7rem;
}

.home-feed-section-category .container {
  border-top: 1px solid color-mix(in srgb, var(--m3-outline-variant) 72%, transparent);
  padding-top: .82rem;
}

.home-feed-section-category-first .container {
  border-top: 0;
  padding-top: 0;
}

.home-first-split {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(300px, 1fr);
  gap: .78rem;
  align-items: start;
}

.home-first-main {
  min-width: 0;
}

.home-first-timeline {
  min-width: 0;
  background: var(--m3-surface-container-low);
  border: 1px solid color-mix(in srgb, var(--m3-outline-variant) 84%, transparent);
  border-radius: 12px;
  padding: .62rem .68rem;
}

.home-feed-head-timeline {
  margin-bottom: .4rem;
}

.home-timeline-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
}

.home-timeline-item + .home-timeline-item {
  border-top: 1px solid color-mix(in srgb, var(--m3-outline-variant) 60%, transparent);
}

.home-timeline-link {
  display: grid;
  gap: .16rem;
  padding: .5rem .08rem;
}

.home-timeline-time {
  font-size: .66rem;
  color: var(--m3-on-surface-variant);
  font-weight: 700;
}

.home-timeline-title {
  font-size: .78rem;
  line-height: 1.3;
  color: var(--m3-on-surface);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.home-timeline-link:hover .home-timeline-title {
  color: var(--m3-primary);
}

.home-timeline-empty {
  font-size: .78rem;
  color: var(--m3-on-surface-variant);
  padding: .2rem 0 .1rem;
}

.home-magazine-layout {
  display: grid;
  gap: .58rem;
}

.home-magazine-top,
.home-magazine-mid,
.home-magazine-grid {
  display: grid;
  gap: .58rem;
}

.home-magazine-top-a {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.home-magazine-top-b {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.home-magazine-top-c {
  grid-template-columns: 1fr;
}

.home-magazine-mid-c {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.home-magazine-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.home-news-card {
  min-width: 0;
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  border: 0;
  display: flex;
  flex-direction: column;
}

.home-news-card-image-link {
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #dfe7f3;
  border-radius: 10px;
}

.home-news-card-lg .home-news-card-image-link {
  aspect-ratio: 16 / 9;
}

.home-news-card-md .home-news-card-image-link {
  aspect-ratio: 16 / 10;
}

.home-news-card-hero .home-news-card-image-link {
  aspect-ratio: 21 / 9;
}

.home-news-card-sm .home-news-card-image-link {
  aspect-ratio: 16 / 10;
}

.home-news-card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: inherit;
}

.home-news-card-image-placeholder {
  background: linear-gradient(130deg, #dbe8f8, #c9d7eb);
  border-radius: inherit;
}

.home-news-card-body {
  padding: .44rem .52rem .48rem;
  display: flex;
  flex-direction: column;
  gap: .2rem;
  flex: 1;
}

.home-news-card-title {
  margin: 0;
  font-size: .8rem;
  line-height: 1.28;
  font-weight: 700;
  color: var(--m3-on-surface);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.home-news-card-lg .home-news-card-title,
.home-news-card-hero .home-news-card-title {
  font-size: .95rem;
  -webkit-line-clamp: 3;
}

.home-news-card-title a {
  color: inherit;
}

.home-news-card-meta {
  margin-top: .12rem;
  font-size: .66rem;
  color: var(--m3-on-surface-variant);
}

.home-news-card-actions {
  margin-top: .24rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.home-news-card-actions-top {
  margin-top: 0;
  padding: .3rem .52rem 0;
}

.home-news-card-action {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  color: var(--m3-on-surface-variant);
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
  min-height: auto;
  font-size: .8rem;
  font-weight: 700;
}

.home-news-card-action svg {
  width: 22px;
  height: 22px;
  flex-basis: 22px;
}

.home-news-card-bookmark {
  width: auto;
  min-width: 0;
  cursor: pointer;
}

.home-news-card-bookmark.is-bookmarked {
  color: #dc2626;
}

@media (max-width: 1280px) {
  .home-magazine-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1024px) {
  .home-magazine-top-b {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .home-first-split {
    grid-template-columns: 1fr;
  }

  .home-first-timeline {
    order: 1;
  }

  .home-first-main {
    order: 2;
  }

  .home-magazine-top-a,
  .home-magazine-top-b,
  .home-magazine-mid-c {
    grid-template-columns: 1fr;
  }

  .home-magazine-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .home-magazine-grid {
    grid-template-columns: 1fr;
  }
}

/* ===== Ads (Foxiz-like controls) ===== */
.header-top-ad-wrap {
  padding: 10px 0 12px;
}

.ad-slot {
  width: 100%;
  margin: 12px 0;
}

.ad-slot.ad-align-full {
  text-align: center;
}

.ad-slot.ad-align-left {
  text-align: left;
}

.ad-slot.ad-align-right {
  text-align: right;
}

.ad-slot-inner {
  display: inline-block;
  width: 100%;
}

.ad-slot-label {
  display: inline-block;
  font-size: 11px;
  line-height: 1;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 7px;
}

.ad-slot-script {
  width: 100%;
}

.ad-slot-image-link {
  display: inline-block;
  max-width: 100%;
}

.ad-slot-image {
  display: block;
  width: 100%;
  height: auto;
}

.ad-slot-image-dark {
  display: none;
}

body.theme-dark .ad-slot-image-dark {
  display: block;
}

body.theme-dark .ad-slot-image-link.has-dark-image .ad-slot-image-light {
  display: none;
}

body.theme-dark .ad-slot-image-link.has-dark-image .ad-slot-image-dark {
  display: block;
}

.ad-slot-article-inline {
  margin: 18px 0;
  clear: both;
}

.ad-slot-sidebar {
  margin: 12px 0 4px;
}

.article-sidebar .ad-slot-sidebar .ad-slot-inner,
.search-sidebar .ad-slot-sidebar .ad-slot-inner,
.static-page-sidebar .ad-slot-sidebar .ad-slot-inner {
  width: 100%;
}

.article-content .ad-slot.ad-align-left .ad-slot-inner {
  float: left;
  width: min(100%, 360px);
  margin-right: 18px;
}

.article-content .ad-slot.ad-align-right .ad-slot-inner {
  float: right;
  width: min(100%, 360px);
  margin-left: 18px;
}

.article-content .ad-slot.ad-align-full .ad-slot-inner {
  float: none;
  width: 100%;
}

/* Footer Slide Up */
.footer-slideup {
  position: fixed;
  right: 14px;
  bottom: 14px;
  z-index: 1600;
}

.footer-slideup-toggle {
  min-width: 44px;
  height: 44px;
  border: 1px solid rgba(15, 23, 42, .22);
  border-radius: 999px;
  background: var(--slideup-na-bg, #fff);
  color: var(--slideup-na-color, #0f172a);
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
}

.footer-slideup-panel {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--slideup-bg, rgba(15, 23, 42, .96));
  padding: 16px 48px 16px 16px;
  color: var(--slideup-icon-color, #fff);
  transform: translate3d(0, 108%, 0);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: transform .28s ease, opacity .28s ease, visibility .28s ease;
}

.footer-slideup.is-open .footer-slideup-panel {
  transform: translate3d(0, 0, 0);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.footer-slideup.is-open .footer-slideup-toggle {
  color: var(--slideup-icon-color, #fff);
  background: transparent;
  border-color: rgba(255, 255, 255, .35);
}

.footer-slideup-close {
  position: absolute;
  top: 12px;
  right: 12px;
  border: 0;
  background: transparent;
  color: var(--slideup-icon-color, #fff);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

.footer-slideup-content {
  max-width: 1180px;
  margin: 0 auto;
}

.footer-slideup-content img {
  max-width: 100%;
  height: auto;
  display: block;
}

.footer-slideup-content .adsbygoogle {
  display: block !important;
  width: 100%;
  min-height: 100px;
}

@media (min-width: 1024px) {
  .footer-slideup-content .adsbygoogle {
    min-height: 120px;
  }
}

@media (max-width: 768px) {
  .header-top-ad-wrap {
    padding: 6px 0 8px;
  }

  .ad-slot {
    margin: 9px 0;
  }

  .article-content .ad-slot.ad-align-left .ad-slot-inner,
  .article-content .ad-slot.ad-align-right .ad-slot-inner {
    float: none;
    width: 100%;
    margin: 0;
  }

  .footer-slideup {
    right: 10px;
    bottom: 10px;
  }

  .footer-slideup-panel {
    padding: 12px 40px 12px 12px;
  }
}

/* ===== TV programa ===== */
.tv-program-page {
  padding: 1.1rem 0 2.4rem;
  background: #fff;
}

.tv-program-page.tv-is-loading .tv-nav-panel,
.tv-program-page.tv-is-loading .tv-live-section,
.tv-program-page.tv-is-loading .tv-schedule-section {
  opacity: .72;
}

.tv-program-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.2rem;
  margin-bottom: 1rem;
}

.tv-program-title {
  font-size: clamp(1.5rem, 2vw, 2rem);
  line-height: 1.15;
  margin-bottom: .35rem;
}

.tv-program-lead {
  color: var(--m3-on-surface-variant);
  font-size: .95rem;
  max-width: 760px;
}

.tv-program-reset-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: .4rem .95rem;
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  font-size: .8rem;
  font-weight: 700;
  white-space: nowrap;
  background: #fff;
}

.tv-program-reset-btn:hover {
  border-color: color-mix(in srgb, var(--m3-primary) 35%, var(--m3-outline-variant));
  color: var(--m3-primary);
}

.tv-program-notice {
  border: 1px solid var(--m3-outline-variant);
  border-radius: 16px;
  padding: 1rem 1.1rem;
  background: var(--m3-surface-container-low);
  margin-bottom: 1rem;
}

.tv-program-notice h2 {
  font-size: 1.1rem;
  margin-bottom: .3rem;
}

.tv-program-notice p {
  color: var(--m3-on-surface-variant);
}

.tv-program-notice-meta {
  font-size: .8rem;
  margin-top: .4rem;
}

.tv-program-notice-error {
  color: #b42318;
}

.tv-program-notice.is-warning {
  border-color: #f0b429;
  background: #fff8e1;
}

.tv-nav-panel {
  border: 1px solid var(--m3-outline-variant);
  border-radius: 18px;
  background: #fff;
  padding: .9rem;
  margin-bottom: 1rem;
}

.tv-nav-block + .tv-nav-block {
  margin-top: .8rem;
}

.tv-nav-title {
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--m3-on-surface-variant);
  margin-bottom: .5rem;
}

.tv-day-chips,
.tv-channel-chips {
  display: flex;
  gap: .52rem;
  overflow-x: auto;
  padding-bottom: .2rem;
}

.tv-day-chip,
.tv-channel-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  flex: 0 0 auto;
  min-height: 40px;
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  background: #fff;
  color: var(--m3-on-surface);
  padding: .36rem .8rem;
  font-size: .8rem;
  font-weight: 700;
  transition: all var(--transition);
}

.tv-day-chip:hover,
.tv-channel-chip:hover {
  border-color: color-mix(in srgb, var(--m3-primary) 45%, var(--m3-outline-variant));
  color: var(--m3-primary);
}

.tv-day-chip.is-active,
.tv-channel-chip.is-active {
  background: var(--m3-primary);
  border-color: var(--m3-primary);
  color: var(--m3-on-primary);
}

.tv-channel-chip-icon {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  object-fit: cover;
  flex: 0 0 22px;
}

.tv-channel-chip-icon-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--m3-primary-container);
  color: var(--m3-primary);
  font-size: .64rem;
  font-weight: 800;
}

.tv-live-section {
  margin-bottom: 1rem;
}

.tv-live-header {
  margin-bottom: .55rem;
}

.tv-live-header h2 {
  font-size: 1.05rem;
  margin-bottom: .15rem;
}

.tv-live-header p {
  color: var(--m3-on-surface-variant);
  font-size: .82rem;
}

.tv-live-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem;
}

.tv-live-card {
  border: 1px solid var(--m3-outline-variant);
  border-radius: 14px;
  padding: .7rem .75rem;
  background: #fff;
  transition: box-shadow var(--transition), border-color var(--transition);
}

.tv-live-card:hover {
  border-color: color-mix(in srgb, var(--m3-primary) 35%, var(--m3-outline-variant));
  box-shadow: var(--m3-shadow-1);
}

.tv-live-card.is-selected {
  border-color: var(--m3-primary);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--m3-primary) 55%, transparent);
}

.tv-live-channel {
  display: flex;
  align-items: center;
  gap: .45rem;
  margin-bottom: .45rem;
  font-size: .82rem;
}

.tv-live-channel-icon {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
  flex: 0 0 24px;
}

.tv-live-channel-icon-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--m3-primary-container);
  color: var(--m3-primary);
  font-size: .64rem;
  font-weight: 800;
}

.tv-live-now-label {
  font-size: .65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--m3-primary);
}

.tv-live-now-title {
  font-size: .86rem;
  font-weight: 700;
  line-height: 1.35;
}

.tv-live-time {
  margin-top: .2rem;
  color: var(--m3-on-surface-variant);
  font-size: .74rem;
}

.tv-live-next {
  margin-top: .3rem;
  color: var(--m3-on-surface-variant);
  font-size: .72rem;
}

.tv-schedule-section {
  border: 1px solid var(--m3-outline-variant);
  border-radius: 18px;
  background: #fff;
  padding: .95rem;
}

.tv-schedule-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: .9rem;
  border-bottom: 1px solid var(--m3-outline-variant);
  padding-bottom: .68rem;
  margin-bottom: .68rem;
}

.tv-schedule-header h2 {
  font-size: 1.2rem;
  line-height: 1.2;
}

.tv-schedule-header p {
  color: var(--m3-on-surface-variant);
  font-size: .82rem;
}

.tv-empty-schedule {
  padding: 1rem 0 .55rem;
  color: var(--m3-on-surface-variant);
  font-size: .92rem;
}

.tv-schedule-list {
  list-style: none;
  display: flex;
  flex-direction: column;
}

.tv-schedule-item {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr) auto;
  gap: .8rem;
  padding: .68rem 0;
  border-bottom: 1px solid var(--m3-outline-variant);
  align-items: start;
}

.tv-schedule-item:last-child {
  border-bottom: 0;
}

.tv-schedule-time {
  font-size: .78rem;
  font-weight: 800;
  color: var(--m3-on-surface-variant);
  white-space: nowrap;
}

.tv-schedule-time-sep {
  display: inline-block;
  margin: 0 .2rem;
}

.tv-schedule-content h3 {
  font-size: .95rem;
  line-height: 1.35;
  margin-bottom: .18rem;
}

.tv-schedule-content p {
  color: var(--m3-on-surface-variant);
  font-size: .8rem;
  line-height: 1.48;
}

.tv-live-badge {
  align-self: center;
  border-radius: 999px;
  padding: .2rem .5rem;
  background: #d92d20;
  color: #fff;
  font-size: .65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.tv-schedule-item.is-live-now .tv-schedule-content h3 {
  color: var(--m3-primary);
}

@media (max-width: 1100px) {
  .tv-live-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .tv-program-hero {
    flex-direction: column;
    gap: .7rem;
  }

  .tv-program-reset-btn {
    min-height: 36px;
    padding: .35rem .8rem;
    font-size: .76rem;
  }

  .tv-live-grid {
    grid-template-columns: 1fr;
  }

  .tv-schedule-header {
    flex-direction: column;
    align-items: flex-start;
    gap: .3rem;
  }

  .tv-schedule-item {
    grid-template-columns: 1fr;
    gap: .3rem;
  }

  .tv-schedule-time {
    font-size: .75rem;
  }

  .tv-live-badge {
    justify-self: flex-start;
  }
}

/* ===== Orai ===== */
.weather-page {
  padding: 1.1rem 0 2.4rem;
  background: #fff;
}

.weather-page.weather-is-loading .weather-days-section,
.weather-page.weather-is-loading .weather-hourly-section {
  opacity: .72;
}

.weather-hero {
  margin-bottom: 1rem;
}

.weather-hero-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.weather-title {
  font-size: clamp(1.5rem, 2vw, 2rem);
  line-height: 1.15;
  margin-bottom: .35rem;
}

.weather-lead {
  color: var(--m3-on-surface-variant);
  font-size: .95rem;
  max-width: 820px;
}

.weather-search-form {
  margin-top: .85rem;
}

.weather-search-label {
  display: inline-block;
  font-size: .78rem;
  font-weight: 700;
  margin-bottom: .38rem;
}

.weather-search-row {
  display: flex;
  gap: .6rem;
  align-items: flex-start;
}

.weather-search-input-wrap {
  position: relative;
  flex: 1;
  min-width: 0;
}

.weather-search-input {
  width: 100%;
  min-height: 44px;
  border-radius: 999px;
  border: 1px solid var(--m3-outline-variant);
  background: #fff;
  padding: .7rem 1rem;
  font-size: .9rem;
  color: var(--m3-on-surface);
}

.weather-search-input:focus {
  outline: none;
  border-color: color-mix(in srgb, var(--m3-primary) 45%, var(--m3-outline-variant));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--m3-primary) 18%, transparent);
}

.weather-search-btn {
  min-height: 44px;
  border-radius: 999px;
  border: 1px solid var(--m3-primary);
  background: var(--m3-primary);
  color: var(--m3-on-primary);
  padding: .62rem 1rem;
  font-size: .82rem;
  font-weight: 700;
  white-space: nowrap;
}

.weather-search-btn:hover {
  filter: brightness(1.03);
}

.weather-autocomplete {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid var(--m3-outline-variant);
  border-radius: 14px;
  box-shadow: var(--m3-shadow-2);
  max-height: 340px;
  overflow-y: auto;
  z-index: 15;
}

.weather-autocomplete-item {
  width: 100%;
  text-align: left;
  display: grid;
  gap: .12rem;
  padding: .62rem .78rem;
  border: 0;
  border-bottom: 1px solid var(--m3-outline-variant);
  background: transparent;
  cursor: pointer;
}

.weather-autocomplete-item:last-child {
  border-bottom: 0;
}

.weather-autocomplete-item strong {
  font-size: .85rem;
  line-height: 1.35;
}

.weather-autocomplete-item span {
  font-size: .74rem;
  color: var(--m3-on-surface-variant);
}

.weather-autocomplete-item:hover {
  background: var(--m3-surface-container-low);
}

.weather-updated {
  margin-top: .5rem;
  color: var(--m3-on-surface-variant);
  font-size: .78rem;
}

.weather-warning {
  margin-top: .45rem;
  border-radius: 10px;
  border: 1px solid #f0b429;
  background: #fff8e1;
  padding: .5rem .7rem;
  font-size: .8rem;
}

.weather-days-section {
  margin-bottom: 1rem;
}

.weather-days-head {
  margin-bottom: .55rem;
}

.weather-days-head h2 {
  font-size: 1.08rem;
  margin-bottom: .15rem;
}

.weather-days-head p {
  color: var(--m3-on-surface-variant);
  font-size: .82rem;
}

.weather-days-slider {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .45rem;
  align-items: stretch;
}

.weather-days-arrow {
  width: 38px;
  min-height: 100%;
  border: 1px solid var(--m3-outline-variant);
  border-radius: 12px;
  background: #fff;
  font-size: 1.24rem;
  color: var(--m3-on-surface-variant);
}

.weather-days-arrow:hover {
  color: var(--m3-primary);
  border-color: color-mix(in srgb, var(--m3-primary) 35%, var(--m3-outline-variant));
}

.weather-days-track {
  display: flex;
  gap: .6rem;
  overflow-x: auto;
  scroll-behavior: smooth;
  padding-bottom: .2rem;
}

.weather-day-card {
  flex: 0 0 260px;
  border: 1px solid var(--m3-outline-variant);
  border-radius: 14px;
  background: #fff;
  padding: .65rem .72rem;
  text-align: left;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.weather-day-card:hover {
  border-color: color-mix(in srgb, var(--m3-primary) 38%, var(--m3-outline-variant));
  box-shadow: var(--m3-shadow-1);
}

.weather-day-card.is-active {
  border-color: var(--m3-primary);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--m3-primary) 58%, transparent);
}

.weather-day-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  margin-bottom: .2rem;
}

.weather-day-label {
  font-size: .9rem;
  font-weight: 800;
}

.weather-day-icon {
  font-size: 1.12rem;
  line-height: 1;
}

.weather-day-sub {
  font-size: .72rem;
  color: var(--m3-on-surface-variant);
  margin-bottom: .46rem;
}

.weather-day-temps,
.weather-day-meta {
  font-size: .76rem;
  line-height: 1.42;
  color: var(--m3-on-surface-variant);
}

.weather-day-temps strong,
.weather-day-meta strong {
  color: var(--m3-on-surface);
  font-weight: 700;
}

.weather-hourly-section {
  margin-top: .8rem;
}

.weather-hourly-head {
  margin-bottom: .55rem;
}

.weather-hourly-head h2 {
  font-size: 1.1rem;
  margin-bottom: .12rem;
}

.weather-hourly-head p {
  color: var(--m3-on-surface-variant);
  font-size: .82rem;
}

.weather-hourly-list {
  display: flex;
  flex-direction: column;
  gap: .55rem;
}

.weather-hour-card {
  border: 1px solid var(--m3-outline-variant);
  border-radius: 14px;
  background: #fff;
  padding: .68rem .78rem;
  display: grid;
  grid-template-columns: 80px 190px minmax(0, 1fr);
  gap: .6rem .8rem;
  align-items: start;
}

.weather-hour-time {
  font-size: .88rem;
  font-weight: 800;
  color: var(--m3-on-surface-variant);
  white-space: nowrap;
}

.weather-hour-condition {
  display: flex;
  align-items: center;
  gap: .42rem;
  font-size: .82rem;
  font-weight: 700;
}

.weather-hour-icon {
  font-size: 1.08rem;
  line-height: 1;
}

.weather-hour-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: .45rem .65rem;
}

.weather-hour-item span {
  display: block;
  font-size: .68rem;
  color: var(--m3-on-surface-variant);
  margin-bottom: .08rem;
}

.weather-hour-item strong {
  font-size: .77rem;
  color: var(--m3-on-surface);
  font-weight: 700;
}

.weather-empty {
  border: 1px solid var(--m3-outline-variant);
  border-radius: 12px;
  background: #fff;
  padding: .82rem .88rem;
  color: var(--m3-on-surface-variant);
  font-size: .84rem;
}

.weather-source {
  margin-top: .55rem;
  font-size: .72rem;
  color: var(--m3-on-surface-variant);
}

@media (max-width: 1100px) {
  .weather-hour-card {
    grid-template-columns: 72px 170px minmax(0, 1fr);
  }

  .weather-hour-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .weather-search-row {
    flex-direction: column;
  }

  .weather-search-btn {
    width: 100%;
  }

  .weather-days-slider {
    grid-template-columns: 1fr;
  }

  .weather-days-arrow {
    display: none;
  }

  .weather-day-card {
    flex: 0 0 min(68vw, 244px);
  }

  .weather-hour-card {
    grid-template-columns: 1fr;
    gap: .28rem;
  }

  .weather-hour-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ===== TV + Weather dark mode ===== */
body.theme-dark .tv-program-page,
body.theme-dark .weather-page {
  background: transparent;
}

body.theme-dark .tv-program-title,
body.theme-dark .tv-nav-title,
body.theme-dark .tv-live-header h2,
body.theme-dark .tv-schedule-header h2,
body.theme-dark .tv-live-now-title,
body.theme-dark .tv-schedule-content h3,
body.theme-dark .weather-title,
body.theme-dark .weather-days-head h2,
body.theme-dark .weather-hourly-head h2,
body.theme-dark .weather-hour-item strong {
  color: var(--m3-on-surface);
}

body.theme-dark .tv-program-reset-btn,
body.theme-dark .tv-nav-panel,
body.theme-dark .tv-day-chip,
body.theme-dark .tv-channel-chip,
body.theme-dark .tv-live-card,
body.theme-dark .tv-schedule-section,
body.theme-dark .weather-search-input,
body.theme-dark .weather-autocomplete,
body.theme-dark .weather-days-arrow,
body.theme-dark .weather-day-card,
body.theme-dark .weather-hour-card,
body.theme-dark .weather-empty {
  background: var(--m3-surface-container-low);
  border-color: var(--m3-outline-variant);
  color: var(--m3-on-surface);
}

body.theme-dark .tv-live-card.is-selected,
body.theme-dark .weather-day-card.is-active {
  border-color: var(--m3-primary);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--m3-primary) 60%, transparent);
}

body.theme-dark .tv-day-chip:hover,
body.theme-dark .tv-channel-chip:hover,
body.theme-dark .tv-live-card:hover,
body.theme-dark .tv-program-reset-btn:hover,
body.theme-dark .weather-days-arrow:hover,
body.theme-dark .weather-day-card:hover {
  border-color: color-mix(in srgb, var(--m3-primary) 45%, var(--m3-outline-variant));
}

body.theme-dark .tv-day-chip.is-active,
body.theme-dark .tv-channel-chip.is-active {
  background: var(--m3-primary);
  border-color: var(--m3-primary);
  color: var(--m3-on-primary);
}

body.theme-dark .tv-program-notice {
  background: var(--m3-surface-container);
  border-color: var(--m3-outline-variant);
}

body.theme-dark .tv-program-notice.is-warning {
  background: color-mix(in srgb, var(--m3-warning) 16%, var(--m3-surface-container));
  border-color: color-mix(in srgb, var(--m3-warning) 62%, var(--m3-outline-variant));
}

body.theme-dark .tv-program-notice-error {
  color: #ff8f89;
}

body.theme-dark .tv-live-time,
body.theme-dark .tv-live-next,
body.theme-dark .tv-schedule-time,
body.theme-dark .tv-schedule-content p,
body.theme-dark .weather-lead,
body.theme-dark .weather-updated,
body.theme-dark .weather-source,
body.theme-dark .weather-day-sub,
body.theme-dark .weather-day-temps,
body.theme-dark .weather-day-meta,
body.theme-dark .weather-hourly-head p,
body.theme-dark .weather-days-head p,
body.theme-dark .weather-hour-item span,
body.theme-dark .weather-empty,
body.theme-dark .weather-autocomplete-item span,
body.theme-dark .weather-warning {
  color: var(--m3-on-surface-variant);
}

body.theme-dark .tv-schedule-header {
  border-bottom-color: var(--m3-outline-variant);
}

body.theme-dark .tv-schedule-item {
  border-bottom-color: var(--m3-outline-variant);
}

body.theme-dark .weather-search-input::placeholder {
  color: color-mix(in srgb, var(--m3-on-surface-variant) 88%, transparent);
}

body.theme-dark .weather-search-input:focus {
  border-color: color-mix(in srgb, var(--m3-primary) 55%, var(--m3-outline-variant));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--m3-primary) 24%, transparent);
}

body.theme-dark .weather-autocomplete-item {
  border-bottom-color: var(--m3-outline-variant);
  color: var(--m3-on-surface);
}

body.theme-dark .weather-autocomplete-item:hover {
  background: var(--m3-surface-container);
}

body.theme-dark .weather-warning {
  background: color-mix(in srgb, var(--m3-warning) 16%, var(--m3-surface-container));
  border-color: color-mix(in srgb, var(--m3-warning) 62%, var(--m3-outline-variant));
}

/* ===== Topbar install icon ===== */
.header-top-install-icon {
  width: 16px;
  height: 16px;
  display: block;
  object-fit: contain;
}

.header-top-action-icon {
  width: 16px;
  height: 16px;
  display: block;
}

.header-top-icon-link {
  padding: 0 !important;
  width: 20px;
  height: 20px;
}

@media (max-width: 760px) {
  .header-top-inner {
    gap: .35rem;
  }

  .header-date {
    font-size: .66rem !important;
    white-space: nowrap;
    max-width: 42vw;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .header-top-right {
    flex-wrap: nowrap;
    gap: .35rem !important;
    white-space: nowrap;
    min-width: 0;
  }

  .header-top-search-link {
    font-size: .75rem !important;
  }

  .header-top-install-icon {
    width: 14px;
    height: 14px;
  }

  .header-top-action-icon {
    width: 15px;
    height: 15px;
  }

  .header-top-icon-link {
    width: 20px;
    height: 20px;
  }
}
