/*
Theme Name: Custom Auto Theme
Author: System
Version: 1.0
*/

:root {
  --white: #FFFFFF;
  --black: #1A1A1A;
  --cobalt: #0047AB;
  --orange: #D4842A;
  --orange-muted: #E8A854;
  --gray-light: #F5F5F5;
  --gray-mid: #999;
  --gray-dark: #555;
  --font-display: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --font-body: Georgia, 'Times New Roman', serif;
  --max-w: 1280px;
  --gutter: 1.5rem;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font-body); color: var(--black); background: var(--white); line-height: 1.7; overflow-x: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--cobalt); text-decoration: none; transition: color 0.3s ease; }
a:hover { color: var(--orange); }

/* === HEADER === */
.site-header { position: sticky; top: 0; z-index: 100; background: var(--white); border-bottom: 3px solid var(--black); }
.header-inner { max-width: var(--max-w); margin: 0 auto; padding: 1rem var(--gutter); display: flex; align-items: center; justify-content: space-between; }
.logo { font-family: var(--font-display); font-size: 2rem; font-weight: 900; letter-spacing: -0.05em; color: var(--black); text-decoration: none; }
.logo span { color: var(--cobalt); }
.nav-links { display: flex; gap: 1.5rem; align-items: center; }
.nav-links a { font-family: var(--font-display); font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.15em; color: var(--black); position: relative; }
.nav-links a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 2px; background: var(--cobalt); transition: width 0.3s ease; }
.nav-links a:hover::after { width: 100%; }
.nav-links a:hover { color: var(--cobalt); }

/* Burger */
.burger { display: none; background: none; border: none; cursor: pointer; width: 44px; height: 44px; position: relative; }
.burger span { display: block; width: 24px; height: 2px; background: var(--black); margin: 5px auto; transition: 0.3s; }
.nav-toggle { display: none; }

@media (max-width: 768px) {
  .burger { display: flex; align-items: center; justify-content: center; flex-direction: column; }
  .nav-links { display: none; position: absolute; top: 100%; left: 0; right: 0; background: var(--white); flex-direction: column; padding: 2rem; border-bottom: 3px solid var(--black); gap: 1rem; }
  .nav-toggle:checked ~ .nav-links { display: flex; }
  .nav-toggle:checked ~ .burger span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
  .nav-toggle:checked ~ .burger span:nth-child(2) { opacity: 0; }
  .nav-toggle:checked ~ .burger span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }
}

/* === HERO SECTION (Swiss shifted) === */
.hero-shifted { max-width: var(--max-w); margin: 0 auto; padding: 4rem var(--gutter) 3rem; display: grid; grid-template-columns: 1fr 1fr 1fr 1fr 1fr; gap: 2rem; min-height: 70vh; align-items: end; }
.hero-headline { grid-column: 1 / 4; }
.hero-headline h1 { font-family: var(--font-display); font-size: clamp(3rem, 8vw, 6rem); font-weight: 900; line-height: 0.95; letter-spacing: -0.04em; color: var(--black); margin-bottom: 1.5rem; }
.hero-headline .hero-tag { font-family: var(--font-display); font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.2em; color: var(--cobalt); margin-bottom: 1rem; display: inline-block; border-bottom: 2px solid var(--cobalt); padding-bottom: 0.25rem; }
.hero-text { grid-column: 4 / 6; font-size: 1.05rem; color: var(--gray-dark); border-left: 3px solid var(--orange); padding-left: 1.5rem; align-self: center; }
.hero-text .author { font-family: var(--font-display); font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--gray-mid); margin-top: 1rem; }

@media (max-width: 768px) {
  .hero-shifted { grid-template-columns: 1fr; padding: 2rem var(--gutter); min-height: auto; }
  .hero-headline { grid-column: 1; }
  .hero-text { grid-column: 1; border-left: 3px solid var(--orange); }
}

/* === PULL QUOTE === */
.pull-quote { max-width: var(--max-w); margin: 0 auto; padding: 3rem var(--gutter); }
.pull-quote blockquote { font-family: var(--font-display); font-size: clamp(1.8rem, 4vw, 3rem); font-weight: 900; line-height: 1.15; color: var(--cobalt); position: relative; padding-left: 2rem; border-left: 6px solid var(--orange); }
.pull-quote cite { display: block; font-family: var(--font-display); font-size: 0.8rem; font-weight: 400; font-style: normal; text-transform: uppercase; letter-spacing: 0.15em; color: var(--gray-mid); margin-top: 1rem; }

/* === THREE COLUMNS (asymmetric) === */
.tri-col { max-width: var(--max-w); margin: 0 auto; padding: 3rem var(--gutter); display: grid; grid-template-columns: 2fr 1.2fr 1.5fr; gap: 2.5rem; }
.tri-col .col { }
.tri-col .col h2 { font-family: var(--font-display); font-size: 1.6rem; font-weight: 900; letter-spacing: -0.02em; margin-bottom: 1rem; line-height: 1.15; }
.tri-col .col h3 { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; margin-bottom: 0.75rem; color: var(--cobalt); }
.tri-col .col p { margin-bottom: 1rem; }

@media (max-width: 768px) {
  .tri-col { grid-template-columns: 1fr; }
}

/* === VERTICAL NOTE STRIP === */
.note-strip-section { max-width: var(--max-w); margin: 0 auto; padding: 3rem var(--gutter); display: grid; grid-template-columns: 60px 1fr; gap: 2rem; }
.note-strip { writing-mode: vertical-rl; text-orientation: mixed; font-family: var(--font-display); font-size: 0.7rem; font-weight: 900; text-transform: uppercase; letter-spacing: 0.3em; color: var(--orange); background: var(--gray-light); padding: 1.5rem 0.5rem; text-align: center; }
.note-content h2 { font-family: var(--font-display); font-size: 2rem; font-weight: 900; margin-bottom: 1.5rem; letter-spacing: -0.02em; }
.note-content p { margin-bottom: 1rem; }

@media (max-width: 768px) {
  .note-strip-section { grid-template-columns: 1fr; }
  .note-strip { writing-mode: horizontal-tb; padding: 0.75rem 1rem; }
}

/* === IMAGE BLOCK === */
.img-block { max-width: var(--max-w); margin: 0 auto; padding: 2rem var(--gutter); display: grid; grid-template-columns: 3fr 2fr; gap: 2.5rem; align-items: center; }
.img-block img { width: 100%; aspect-ratio: 16/10; object-fit: cover; }
.img-block .img-caption { font-family: var(--font-display); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--gray-mid); margin-top: 0.5rem; }
.img-block-text h2 { font-family: var(--font-display); font-size: 1.8rem; font-weight: 900; margin-bottom: 1rem; letter-spacing: -0.02em; }
.img-block-text p { margin-bottom: 1rem; }

.img-block.reverse { grid-template-columns: 2fr 3fr; }
.img-block.reverse .img-wrap { order: 2; }
.img-block.reverse .img-block-text { order: 1; }

@media (max-width: 768px) {
  .img-block, .img-block.reverse { grid-template-columns: 1fr; }
  .img-block.reverse .img-wrap { order: 0; }
  .img-block.reverse .img-block-text { order: 0; }
}

/* === CARDS === */
.cards-section { max-width: var(--max-w); margin: 0 auto; padding: 3rem var(--gutter); }
.cards-section .section-label { font-family: var(--font-display); font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.2em; color: var(--cobalt); margin-bottom: 0.5rem; }
.cards-section h2 { font-family: var(--font-display); font-size: 2.5rem; font-weight: 900; letter-spacing: -0.03em; margin-bottom: 2rem; }
.cards-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.card { background: var(--gray-light); padding: 2rem; position: relative; overflow: hidden; transition: transform 0.3s ease, box-shadow 0.3s ease; }
.card:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,0.1); }
.card::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 4px; background: var(--cobalt); transform: scaleX(0); transform-origin: left; transition: transform 0.4s ease; }
.card:hover::before { transform: scaleX(1); }
.card .card-num { font-family: var(--font-display); font-size: 3rem; font-weight: 900; color: rgba(0,71,171,0.1); line-height: 1; margin-bottom: 0.5rem; }
.card h3 { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; margin-bottom: 0.75rem; }
.card p { font-size: 0.95rem; color: var(--gray-dark); }

@media (max-width: 768px) {
  .cards-grid { grid-template-columns: 1fr; }
}

/* === SIDEBAR LAYOUT === */
.sidebar-layout { max-width: var(--max-w); margin: 0 auto; padding: 3rem var(--gutter); display: grid; grid-template-columns: 1fr 300px; gap: 3rem; }
.sidebar-main h2 { font-family: var(--font-display); font-size: 2rem; font-weight: 900; margin-bottom: 1.5rem; letter-spacing: -0.02em; }
.sidebar-main p { margin-bottom: 1rem; }
.sidebar { }
.sidebar-box { background: var(--gray-light); padding: 1.5rem; margin-bottom: 1.5rem; }
.sidebar-box h3 { font-family: var(--font-display); font-size: 1rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 1rem; color: var(--cobalt); }
.sidebar-box ul { list-style: none; }
.sidebar-box li { padding: 0.5rem 0; border-bottom: 1px solid rgba(0,0,0,0.08); font-size: 0.9rem; }
.sidebar-box li:last-child { border-bottom: none; }
.sidebar-box li a { color: var(--black); font-family: var(--font-display); font-weight: 600; font-size: 0.85rem; }
.sidebar-box li a:hover { color: var(--cobalt); }
.sidebar-highlight { background: var(--cobalt); color: var(--white); padding: 2rem; }
.sidebar-highlight h3 { color: var(--orange-muted); }
.sidebar-highlight p { font-size: 0.9rem; line-height: 1.6; color: rgba(255,255,255,0.9); }

@media (max-width: 768px) {
  .sidebar-layout { grid-template-columns: 1fr; }
}

/* === NEWSLETTER === */
.newsletter { background: var(--black); color: var(--white); padding: 4rem var(--gutter); text-align: center; }
.newsletter-inner { max-width: 600px; margin: 0 auto; }
.newsletter h2 { font-family: var(--font-display); font-size: 2.5rem; font-weight: 900; letter-spacing: -0.03em; margin-bottom: 1rem; }
.newsletter p { font-size: 1rem; color: rgba(255,255,255,0.7); margin-bottom: 2rem; }
.newsletter-form { display: flex; gap: 0; max-width: 480px; margin: 0 auto; }
.newsletter-form input[type="email"] { flex: 1; padding: 1rem 1.25rem; border: 2px solid rgba(255,255,255,0.3); background: transparent; color: var(--white); font-family: var(--font-display); font-size: 0.9rem; outline: none; transition: border-color 0.3s; }
.newsletter-form input[type="email"]::placeholder { color: rgba(255,255,255,0.4); }
.newsletter-form input[type="email"]:focus { border-color: var(--orange); }
.newsletter-form button { padding: 1rem 2rem; background: var(--cobalt); color: var(--white); border: none; font-family: var(--font-display); font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.15em; cursor: pointer; transition: background 0.3s; min-width: 44px; min-height: 44px; }
.newsletter-form button:hover { background: var(--orange); }

@media (max-width: 480px) {
  .newsletter-form { flex-direction: column; }
}

/* === FOOTER === */
.site-footer { border-top: 3px solid var(--black); padding: 3rem var(--gutter); }
.footer-inner { max-width: var(--max-w); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.footer-brand .logo { font-size: 1.5rem; margin-bottom: 0.5rem; display: inline-block; }
.footer-brand p { font-size: 0.8rem; color: var(--gray-mid); }
.footer-links { text-align: right; }
.footer-links a { font-family: var(--font-display); font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--gray-mid); margin-left: 1.5rem; }
.footer-links a:hover { color: var(--cobalt); }
.footer-disclaimer { grid-column: 1 / -1; font-size: 0.75rem; color: var(--gray-mid); border-top: 1px solid rgba(0,0,0,0.1); padding-top: 1.5rem; margin-top: 1rem; line-height: 1.6; }

@media (max-width: 768px) {
  .footer-inner { grid-template-columns: 1fr; }
  .footer-links { text-align: left; }
  .footer-links a { margin-left: 0; margin-right: 1rem; }
}

/* === DIVIDER === */
.swiss-divider { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--gutter); }
.swiss-divider hr { border: none; height: 1px; background: rgba(0,0,0,0.12); }
.swiss-divider.thick hr { height: 3px; background: var(--black); }

/* === ARTICLE PAGE === */
.article-hero { max-width: var(--max-w); margin: 0 auto; padding: 4rem var(--gutter) 2rem; }
.article-hero .article-cat { font-family: var(--font-display); font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.2em; color: var(--cobalt); border: 2px solid var(--cobalt); padding: 0.3rem 0.75rem; display: inline-block; margin-bottom: 1rem; }
.article-hero h1 { font-family: var(--font-display); font-size: clamp(2.5rem, 6vw, 4.5rem); font-weight: 900; line-height: 1; letter-spacing: -0.04em; margin-bottom: 1rem; }
.article-hero .article-meta { font-family: var(--font-display); font-size: 0.8rem; color: var(--gray-mid); text-transform: uppercase; letter-spacing: 0.1em; }

.article-body { max-width: var(--max-w); margin: 0 auto; padding: 2rem var(--gutter); }
.article-content { max-width: 720px; }
.article-content h2 { font-family: var(--font-display); font-size: 1.8rem; font-weight: 900; margin: 2.5rem 0 1rem; letter-spacing: -0.02em; }
.article-content h3 { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; margin: 2rem 0 0.75rem; color: var(--cobalt); }
.article-content p { margin-bottom: 1.25rem; }
.article-content .highlight-box { background: var(--gray-light); padding: 1.5rem 2rem; margin: 2rem 0; border-left: 4px solid var(--cobalt); }
.article-content .highlight-box p { margin-bottom: 0.5rem; }
.article-content .highlight-box p:last-child { margin-bottom: 0; }
.article-content .inline-quote { font-family: var(--font-display); font-size: 1.5rem; font-weight: 900; color: var(--cobalt); margin: 2rem 0; padding: 1.5rem 0; border-top: 2px solid var(--black); border-bottom: 2px solid var(--black); line-height: 1.3; }

.article-img { margin: 2rem 0; }
.article-img img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.article-img figcaption { font-family: var(--font-display); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--gray-mid); margin-top: 0.5rem; }

.article-tags { margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid rgba(0,0,0,0.1); }
.article-tags span { display: inline-block; font-family: var(--font-display); font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; background: var(--gray-light); padding: 0.4rem 0.8rem; margin: 0.25rem; }

/* === SUCCESS PAGE === */
.success-page { max-width: 600px; margin: 0 auto; padding: 8rem var(--gutter); text-align: center; }
.success-page .checkmark { font-size: 4rem; margin-bottom: 1.5rem; }
.success-page h1 { font-family: var(--font-display); font-size: 3rem; font-weight: 900; margin-bottom: 1rem; letter-spacing: -0.03em; }
.success-page p { font-size: 1.1rem; color: var(--gray-dark); margin-bottom: 2rem; }
.btn-primary { display: inline-block; padding: 1rem 2.5rem; background: var(--cobalt); color: var(--white); font-family: var(--font-display); font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.15em; text-decoration: none; transition: background 0.3s; min-height: 44px; }
.btn-primary:hover { background: var(--orange); color: var(--white); }

/* === LEGAL PAGES === */
.legal-page { max-width: 800px; margin: 0 auto; padding: 4rem var(--gutter); }
.legal-page h1 { font-family: var(--font-display); font-size: 2.5rem; font-weight: 900; letter-spacing: -0.03em; margin-bottom: 0.5rem; }
.legal-page .legal-date { font-family: var(--font-display); font-size: 0.8rem; color: var(--gray-mid); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 3rem; }
.legal-page h2 { font-family: var(--font-display); font-size: 1.3rem; font-weight: 700; margin: 2.5rem 0 1rem; color: var(--cobalt); }
.legal-page p { margin-bottom: 1rem; }

/* === 404 === */
.error-page { max-width: 700px; margin: 0 auto; padding: 8rem var(--gutter); text-align: center; }
.error-page .error-num { font-family: var(--font-display); font-size: clamp(6rem, 20vw, 12rem); font-weight: 900; line-height: 1; color: var(--cobalt); opacity: 0.15; }
.error-page h1 { font-family: var(--font-display); font-size: 2rem; font-weight: 900; margin-bottom: 1rem; margin-top: -1rem; }
.error-page p { font-size: 1.05rem; color: var(--gray-dark); margin-bottom: 2rem; }
.error-links { display: flex; flex-wrap: wrap; justify-content: center; gap: 1rem; }
.error-links a { font-family: var(--font-display); font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; padding: 0.75rem 1.5rem; border: 2px solid var(--black); color: var(--black); transition: all 0.3s; min-height: 44px; display: flex; align-items: center; }
.error-links a:hover { background: var(--cobalt); border-color: var(--cobalt); color: var(--white); }

/* === COOKIE BANNER === */
.cookie-overlay { position: fixed; bottom: 1rem; right: 1rem; z-index: 999; max-width: 380px; background: var(--black); color: var(--white); padding: 1.5rem; font-size: 0.85rem; line-height: 1.5; transition: transform 0.4s ease, opacity 0.4s ease; }
.cookie-overlay p { margin-bottom: 1rem; color: rgba(255,255,255,0.8); }
.cookie-overlay a { color: var(--orange-muted); }
.cookie-btns { display: flex; gap: 0.75rem; }
.cookie-btns label, .cookie-btns a { font-family: var(--font-display); font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; padding: 0.6rem 1.2rem; cursor: pointer; text-align: center; min-height: 44px; display: flex; align-items: center; justify-content: center; }
.cookie-accept { background: var(--cobalt); color: var(--white); border: none; }
.cookie-accept:hover { background: var(--orange); }
.cookie-decline { background: transparent; border: 1px solid rgba(255,255,255,0.3); color: var(--white); }
.cookie-decline:hover { border-color: var(--white); }
#cookie-toggle { display: none; }
#cookie-toggle:checked ~ .cookie-overlay { transform: translateY(200%); opacity: 0; pointer-events: none; }

/* === HIGHLIGHT BAR === */
.highlight-bar { background: var(--cobalt); color: var(--white); padding: 2.5rem var(--gutter); }
.highlight-bar-inner { max-width: var(--max-w); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; text-align: center; }
.highlight-bar .stat { }
.highlight-bar .stat-num { font-family: var(--font-display); font-size: 2.5rem; font-weight: 900; }
.highlight-bar .stat-label { font-family: var(--font-display); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.15em; opacity: 0.7; margin-top: 0.25rem; }

@media (max-width: 480px) {
  .highlight-bar-inner { grid-template-columns: 1fr; gap: 1.5rem; }
}

/* === ARTICLES LIST === */
.articles-list { max-width: var(--max-w); margin: 0 auto; padding: 3rem var(--gutter); }
.articles-list h2 { font-family: var(--font-display); font-size: 2rem; font-weight: 900; margin-bottom: 2rem; letter-spacing: -0.02em; }
.articles-list-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.article-preview { display: grid; grid-template-columns: 180px 1fr; gap: 1.5rem; align-items: start; padding-bottom: 2rem; border-bottom: 1px solid rgba(0,0,0,0.1); }
.article-preview img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.article-preview h3 { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; margin-bottom: 0.5rem; line-height: 1.3; }
.article-preview h3 a { color: var(--black); }
.article-preview h3 a:hover { color: var(--cobalt); }
.article-preview p { font-size: 0.9rem; color: var(--gray-dark); line-height: 1.5; }
.article-preview .preview-cat { font-family: var(--font-display); font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.15em; color: var(--cobalt); margin-bottom: 0.5rem; }

@media (max-width: 768px) {
  .articles-list-grid { grid-template-columns: 1fr; }
  .article-preview { grid-template-columns: 120px 1fr; }
}

/* === SCROLL ANIMATIONS === */
@keyframes fadeInUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeInLeft { from { opacity: 0; transform: translateX(-30px); } to { opacity: 1; transform: translateX(0); } }
.animate-in { animation: fadeInUp 0.6s ease forwards; }

/* === MISC === */
.text-cobalt { color: var(--cobalt); }
.text-orange { color: var(--orange); }
.bg-light { background: var(--gray-light); }
.section-spacer { padding: 2rem 0; }
