/*
Theme Name: Custom Auto Theme
Author: System
Version: 1.0
*/
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } html { scroll-behavior: smooth; font-size: 16px; } body { font-family: 'Barlow', sans-serif; color: #1a1a1a; background: #f2f3f5; line-height: 1.72; } a { color: inherit; text-decoration: none; } img { max-width: 100%; height: auto; display: block; } :root { --vn-navy: #0a1628; --vn-blue: #1a3a6b; --vn-accent: #3a7bd5; --vn-white: #ffffff; --vn-light: #f2f3f5; --vn-gray: #e0e2e6; --vn-text: #1a1a1a; --vn-muted: #5a6270; --vn-radius: 3px; --vn-font-head: 'Cormorant Garamond', Georgia, serif; --vn-font-body: 'Barlow', sans-serif; } @import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400&family=Barlow:wght@300;400;500;600;700&display=swap'); .vn-topbar { background: var(--vn-navy); color: rgba(255,255,255,0.6); font-size: 0.72rem; letter-spacing: 0.06em; text-transform: uppercase; padding: 6px 0; } .vn-topbar-inner { max-width: 1220px; margin: 0 auto; padding: 0 20px; display: flex; justify-content: space-between; align-items: center; } .vn-topbar a { color: rgba(255,255,255,0.5); transition: color 0.2s; } .vn-topbar a:hover { color: #fff; } .vn-header { background: var(--vn-white); border-bottom: 3px solid var(--vn-navy); position: sticky; top: 0; z-index: 100; } .vn-header-inner { max-width: 1220px; margin: 0 auto; padding: 14px 20px; display: flex; align-items: center; justify-content: space-between; } .vn-logo { font-family: var(--vn-font-head); font-size: 2.4rem; font-weight: 700; color: var(--vn-navy); letter-spacing: -0.03em; } .vn-logo span { color: var(--vn-accent); } .vn-nav { display: flex; gap: 28px; align-items: center; } .vn-nav a { font-size: 0.82rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.07em; color: #333; transition: color 0.2s; position: relative; } .vn-nav a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 2px; background: var(--vn-accent); transition: width 0.3s; } .vn-nav a:hover::after { width: 100%; } .vn-nav a:hover { color: var(--vn-accent); } .vn-burger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 6px; background: none; border: none; } .vn-burger span { width: 24px; height: 2px; background: var(--vn-navy); transition: all 0.3s; display: block; } .vn-main { max-width: 1220px; margin: 0 auto; padding: 0 20px 60px; } .vn-hero-grid { display: grid; grid-template-columns: 1fr 320px; gap: 0; border-bottom: 2px solid var(--vn-navy); margin-bottom: 36px; } .vn-hero-main { padding: 40px 32px 36px 0; border-right: 1px solid var(--vn-gray); } .vn-hero-tag { display: inline-block; background: var(--vn-accent); color: #fff; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; padding: 3px 12px; margin-bottom: 18px; } .vn-hero-title { font-family: var(--vn-font-head); font-size: clamp(2rem, 4vw, 3rem); line-height: 1.15; color: var(--vn-navy); margin-bottom: 18px; font-weight: 700; } .vn-hero-lead { font-size: 1.1rem; color: var(--vn-muted); line-height: 1.75; margin-bottom: 16px; } .vn-hero-meta { font-size: 0.78rem; color: var(--vn-muted); padding-top: 14px; border-top: 1px solid var(--vn-gray); display: flex; gap: 18px; } .vn-hero-meta strong { color: var(--vn-text); } .vn-sidebar-top { padding: 40px 0 36px 28px; display: flex; flex-direction: column; gap: 20px; } .vn-sidebar-top .vn-sb-label { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--vn-accent); margin-bottom: 4px; } .vn-sb-fact { background: var(--vn-navy); color: #fff; padding: 16px 18px; border-radius: var(--vn-radius); } .vn-sb-fact h4 { font-family: var(--vn-font-head); font-size: 1rem; margin-bottom: 6px; color: #c0d0e8; } .vn-sb-fact p { font-size: 0.84rem; color: rgba(255,255,255,0.78); line-height: 1.55; } .vn-sb-mini { border: 1px solid var(--vn-gray); padding: 14px 16px; border-radius: var(--vn-radius); } .vn-sb-mini h4 { font-family: var(--vn-font-head); font-size: 0.95rem; color: var(--vn-navy); margin-bottom: 6px; } .vn-sb-mini p { font-size: 0.82rem; color: var(--vn-muted); } .vn-content-grid { display: grid; grid-template-columns: 1fr 320px; gap: 0; } .vn-content-main { padding-right: 32px; border-right: 1px solid var(--vn-gray); } .vn-content-side { padding-left: 28px; } .vn-columns { column-count: 2; column-gap: 28px; margin-bottom: 28px; } .vn-columns p { margin-bottom: 14px; font-size: 0.98rem; color: #2a2a2a; break-inside: avoid; } .vn-section-head { font-family: var(--vn-font-head); font-size: 1.6rem; color: var(--vn-navy); margin: 32px 0 14px; padding-left: 14px; border-left: 4px solid var(--vn-accent); line-height: 1.25; } .vn-text p { margin-bottom: 14px; font-size: 0.98rem; color: #2a2a2a; } .vn-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 24px 0; } .vn-info-card { background: var(--vn-white); border: 1px solid var(--vn-gray); border-top: 3px solid var(--vn-accent); padding: 18px 16px; border-radius: var(--vn-radius); transition: transform 0.2s, box-shadow 0.2s; } .vn-info-card:hover { transform: translateY(-3px); box-shadow: 0 6px 20px rgba(10,22,40,0.1); } .vn-info-card h4 { font-family: var(--vn-font-head); font-size: 1rem; color: var(--vn-navy); margin-bottom: 6px; } .vn-info-card p { font-size: 0.84rem; color: var(--vn-muted); line-height: 1.55; } .vn-quote { margin: 28px 0; padding: 22px 26px; background: var(--vn-navy); color: #c8d8f0; border-radius: var(--vn-radius); position: relative; } .vn-quote::before { content: open-quote; font-family: var(--vn-font-head); font-size: 4rem; position: absolute; top: 4px; left: 14px; color: rgba(58,123,213,0.3); line-height: 1; } .vn-quote blockquote { font-family: var(--vn-font-head); font-style: italic; font-size: 1.05rem; line-height: 1.6; padding-left: 24px; } .vn-quote cite { display: block; margin-top: 10px; font-size: 0.75rem; color: #8899b5; font-style: normal; padding-left: 24px; } .vn-img-block { margin: 26px 0; border-radius: var(--vn-radius); overflow: hidden; position: relative; } .vn-img-block img { width: 100%; max-height: 340px; object-fit: cover; } .vn-img-block figcaption { font-size: 0.72rem; color: var(--vn-muted); padding: 8px 0; text-align: right; font-style: italic; } .vn-highlight { background: linear-gradient(135deg, var(--vn-blue), var(--vn-navy)); color: #fff; padding: 24px 26px; margin: 28px 0; border-radius: var(--vn-radius); } .vn-highlight h3 { font-family: var(--vn-font-head); font-size: 1.15rem; margin-bottom: 10px; color: #dce6f5; } .vn-highlight p { font-size: 0.92rem; color: rgba(255,255,255,0.82); line-height: 1.65; } .vn-highlight ul { margin: 12px 0 0 20px; } .vn-highlight ul li { font-size: 0.88rem; color: rgba(255,255,255,0.8); margin-bottom: 5px; } .vn-tip-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 28px 0; } .vn-tip-item { background: var(--vn-white); border: 1px solid var(--vn-gray); padding: 18px 16px; border-radius: var(--vn-radius); text-align: center; transition: transform 0.2s; } .vn-tip-item:hover { transform: translateY(-2px); } .vn-tip-item .vn-tip-icon { font-size: 1.6rem; margin-bottom: 8px; } .vn-tip-item h4 { font-family: var(--vn-font-head); font-size: 0.95rem; color: var(--vn-navy); margin-bottom: 5px; } .vn-tip-item p { font-size: 0.8rem; color: var(--vn-muted); } .vn-sidebar-card { background: var(--vn-white); border: 1px solid var(--vn-gray); padding: 20px 18px; border-radius: var(--vn-radius); margin-bottom: 20px; } .vn-sidebar-card h3 { font-family: var(--vn-font-head); font-size: 1.05rem; color: var(--vn-navy); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 2px solid var(--vn-accent); } .vn-sb-article { padding: 10px 0; border-bottom: 1px solid var(--vn-light); } .vn-sb-article:last-child { border-bottom: none; } .vn-sb-article span { display: block; font-size: 0.68rem; color: var(--vn-accent); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 3px; font-weight: 600; } .vn-sb-article a { font-size: 0.88rem; font-weight: 600; color: var(--vn-text); display: block; line-height: 1.4; transition: color 0.2s; } .vn-sb-article a:hover { color: var(--vn-accent); } .vn-sb-article p { font-size: 0.78rem; color: var(--vn-muted); margin-top: 3px; } .vn-sb-quote { background: var(--vn-navy); color: #c0d0e8; padding: 18px; border-radius: var(--vn-radius); font-style: italic; font-size: 0.9rem; line-height: 1.6; margin-bottom: 20px; } .vn-sb-quote footer { margin-top: 8px; font-style: normal; font-size: 0.72rem; color: #7a90b5; } .vn-sb-list { list-style: none; } .vn-sb-list li { padding: 7px 0; border-bottom: 1px solid var(--vn-light); font-size: 0.86rem; color: #333; } .vn-sb-list li:last-child { border-bottom: none; } .vn-sb-list li::before { content: '\2192 '; color: var(--vn-accent); font-weight: 700; } .vn-newsletter { background: linear-gradient(135deg, var(--vn-navy), var(--vn-blue)); color: #fff; padding: 22px 18px; border-radius: var(--vn-radius); text-align: center; margin-bottom: 20px; } .vn-newsletter h3 { font-family: var(--vn-font-head); margin-bottom: 6px; font-size: 1.05rem; } .vn-newsletter p { font-size: 0.82rem; color: #b0c4e0; margin-bottom: 14px; } .vn-nl-input { width: 100%; padding: 10px 14px; border: none; border-radius: 50px; font-family: var(--vn-font-body); font-size: 0.85rem; margin-bottom: 8px; outline: none; } .vn-nl-btn { width: 100%; padding: 10px; background: var(--vn-accent); color: #fff; font-weight: 700; font-size: 0.82rem; border: none; border-radius: 50px; cursor: pointer; transition: opacity 0.2s; } .vn-nl-btn:hover { opacity: 0.85; } .vn-related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin: 36px 0; } .vn-related-card { background: var(--vn-white); border: 1px solid var(--vn-gray); border-radius: var(--vn-radius); overflow: hidden; transition: transform 0.25s, box-shadow 0.25s; } .vn-related-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(10,22,40,0.12); } .vn-related-card .vn-rc-body { padding: 16px; } .vn-related-card span { font-size: 0.68rem; color: var(--vn-accent); text-transform: uppercase; font-weight: 700; letter-spacing: 0.06em; } .vn-related-card h4 { font-family: var(--vn-font-head); font-size: 1.05rem; color: var(--vn-navy); margin: 6px 0; line-height: 1.3; } .vn-related-card p { font-size: 0.8rem; color: var(--vn-muted); } .vn-tags-row { margin-top: 28px; padding-top: 16px; border-top: 1px solid var(--vn-gray); display: flex; gap: 8px; flex-wrap: wrap; } .vn-tags-row a { font-size: 0.72rem; background: var(--vn-light); padding: 4px 12px; border-radius: 20px; color: var(--vn-muted); transition: all 0.2s; font-weight: 500; } .vn-tags-row a:hover { background: var(--vn-accent); color: #fff; } .vn-footer { background: var(--vn-navy); color: rgba(255,255,255,0.6); padding: 40px 0 20px; } .vn-footer-inner { max-width: 1220px; margin: 0 auto; padding: 0 20px; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; } .vn-footer h4 { font-family: var(--vn-font-head); color: #fff; font-size: 1rem; margin-bottom: 14px; } .vn-footer p, .vn-footer li { font-size: 0.82rem; line-height: 1.7; } .vn-footer ul { list-style: none; } .vn-footer a { color: rgba(255,255,255,0.5); transition: color 0.2s; } .vn-footer a:hover { color: #fff; } .vn-footer-bottom { max-width: 1220px; margin: 28px auto 0; padding: 16px 20px 0; border-top: 1px solid rgba(255,255,255,0.08); font-size: 0.72rem; color: rgba(255,255,255,0.35); } .vn-footer-bottom a { color: rgba(255,255,255,0.4); } .vn-disclaimer { margin-top: 12px; font-size: 0.7rem; color: rgba(255,255,255,0.3); line-height: 1.6; } .vn-breadcrumb { max-width: 1220px; margin: 0 auto; padding: 12px 20px; font-size: 0.76rem; color: #888; } .vn-breadcrumb a { color: var(--vn-accent); } .vn-page-title { font-family: var(--vn-font-head); font-size: 2rem; color: var(--vn-navy); margin-bottom: 24px; text-align: center; padding: 36px 0 20px; } .vn-legal { max-width: 800px; margin: 0 auto; padding: 0 20px 60px; } .vn-legal h2 { font-family: var(--vn-font-head); font-size: 1.2rem; color: var(--vn-navy); margin: 24px 0 10px; } .vn-legal p { font-size: 0.92rem; color: #2a2a2a; margin-bottom: 12px; } .vn-success-wrap { max-width: 600px; margin: 0 auto; padding: 80px 20px; text-align: center; } .vn-success-wrap h1 { font-family: var(--vn-font-head); font-size: 2.2rem; color: var(--vn-navy); margin-bottom: 16px; } .vn-success-wrap p { color: var(--vn-muted); margin-bottom: 24px; } .vn-btn { display: inline-block; background: var(--vn-accent); color: #fff; padding: 12px 28px; border-radius: 50px; font-weight: 600; font-size: 0.88rem; transition: opacity 0.2s; } .vn-btn:hover { opacity: 0.85; } .vn-404-wrap { max-width: 600px; margin: 0 auto; padding: 80px 20px; text-align: center; } .vn-404-wrap h1 { font-family: var(--vn-font-head); font-size: 5rem; color: var(--vn-navy); margin-bottom: 8px; } .vn-404-wrap h2 { font-family: var(--vn-font-head); font-size: 1.5rem; color: var(--vn-muted); margin-bottom: 24px; } .vn-404-links { display: flex; flex-direction: column; gap: 10px; align-items: center; } .vn-404-links a { color: var(--vn-accent); font-weight: 600; } .vn-cookie-toggle { display: none; } .vn-cookie-banner { position: fixed; bottom: 20px; right: 20px; background: var(--vn-navy); color: #c0d0e8; padding: 20px 22px; border-radius: 6px; max-width: 360px; font-size: 0.82rem; z-index: 999; box-shadow: 0 8px 32px rgba(0,0,0,0.3); line-height: 1.55; display: block; } .vn-cookie-toggle:checked ~ .vn-cookie-banner { display: none; } .vn-cookie-banner p { margin-bottom: 12px; } .vn-cookie-btns { display: flex; gap: 8px; } .vn-cookie-btns label, .vn-cookie-btns a { padding: 8px 16px; border-radius: 50px; font-size: 0.78rem; font-weight: 600; cursor: pointer; text-align: center; min-width: 44px; min-height: 44px; display: flex; align-items: center; justify-content: center; } .vn-cookie-accept { background: var(--vn-accent); color: #fff; border: none; } .vn-cookie-decline { background: transparent; color: #8899b5; border: 1px solid #334466; } .vn-cookie-link { color: #7a90b5 !important; font-size: 0.72rem; margin-top: 8px; display: inline-block; } @keyframes vnFadeUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } } .vn-anim { animation: vnFadeUp 0.5s ease forwards; } .vn-anim-d1 { animation: vnFadeUp 0.5s 0.1s ease both; } .vn-anim-d2 { animation: vnFadeUp 0.5s 0.2s ease both; } .vn-article-full { max-width: 800px; margin: 0 auto; padding: 0 20px 60px; } .vn-article-full h1 { font-family: var(--vn-font-head); font-size: 2.2rem; color: var(--vn-navy); line-height: 1.2; margin-bottom: 14px; } .vn-article-full .vn-article-meta-row { font-size: 0.8rem; color: var(--vn-muted); margin-bottom: 24px; padding-bottom: 14px; border-bottom: 1px solid var(--vn-gray); } .vn-article-full h2 { font-family: var(--vn-font-head); font-size: 1.4rem; color: var(--vn-navy); margin: 28px 0 12px; padding-left: 12px; border-left: 3px solid var(--vn-accent); } .vn-article-full p { margin-bottom: 14px; font-size: 0.96rem; color: #2a2a2a; } .vn-article-full blockquote { margin: 24px 0; padding: 18px 22px; background: var(--vn-light); border-left: 4px solid var(--vn-navy); font-style: italic; color: #333; font-size: 1rem; } .vn-article-full .vn-art-img { margin: 24px 0; border-radius: var(--vn-radius); overflow: hidden; } .vn-article-full .vn-art-img img { width: 100%; max-height: 340px; object-fit: cover; } .vn-article-full .vn-art-img figcaption { font-size: 0.72rem; color: var(--vn-muted); margin-top: 6px; font-style: italic; } @media (max-width: 900px) { .vn-hero-grid, .vn-content-grid { grid-template-columns: 1fr; } .vn-hero-main { border-right: none; padding-right: 0; border-bottom: 1px solid var(--vn-gray); padding-bottom: 24px; } .vn-sidebar-top { padding-left: 0; padding-top: 20px; } .vn-content-main { border-right: none; padding-right: 0; } .vn-content-side { padding-left: 0; padding-top: 28px; } .vn-columns { column-count: 1; } .vn-info-grid { grid-template-columns: 1fr; } .vn-tip-strip { grid-template-columns: 1fr; } .vn-related-grid { grid-template-columns: 1fr; } .vn-nav { display: none; } .vn-nav.vn-open { display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: #fff; padding: 20px; border-bottom: 3px solid var(--vn-navy); box-shadow: 0 8px 24px rgba(0,0,0,0.1); z-index: 100; } .vn-burger { display: flex; } .vn-footer-inner { grid-template-columns: 1fr; gap: 24px; } } @media (max-width: 480px) { .vn-hero-title { font-size: 1.6rem; } .vn-topbar-inner { flex-direction: column; gap: 4px; text-align: center; } .vn-cookie-banner { left: 12px; right: 12px; max-width: none; bottom: 12px; } }