/*
Theme Name: Custom Auto Theme
Author: System
Version: 1.0
*/
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700;900&family=Inter:wght@300;400;600;700&display=swap'); *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } :root { --blue-deep: #0f1b4c; --indigo: #3d3b8e; --indigo-light: #6c6ab5; --accent: #f5c842; --bg: #f0f0fa; --bg-white: #ffffff; --text: #1a1a2e; --text-light: #555577; --radius: 20px; --shadow: 0 4px 24px rgba(15,27,76,0.10); } html { scroll-behavior: smooth; font-size: 16px; } body { font-family: 'Inter', sans-serif; background: var(--bg); color: var(--text); line-height: 1.75; } h1, h2, h3, h4 { font-family: 'Playfair Display', serif; line-height: 1.2; color: var(--blue-deep); } a { color: var(--indigo); text-decoration: none; transition: color 0.3s; } a:hover { color: var(--accent); } .container { max-width: 1100px; margin: 0 auto; padding: 0 24px; } header { background: var(--blue-deep); color: white; padding: 18px 0; position: sticky; top: 0; z-index: 200; box-shadow: 0 2px 16px rgba(15,27,76,0.35); } header .container { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; } .logo { font-family: 'Playfair Display', serif; font-size: 1.7rem; color: white; font-weight: 900; letter-spacing: 2px; } nav { display: flex; gap: 28px; flex-wrap: wrap; align-items: center; } nav a { color: rgba(255,255,255,0.82); font-size: 0.88rem; font-weight: 600; letter-spacing: 0.5px; transition: color 0.2s; } nav a:hover { color: var(--accent); } footer { background: var(--blue-deep); color: rgba(255,255,255,0.7); padding: 56px 0 28px; margin-top: 80px; } .footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 36px; margin-bottom: 36px; } .footer-col h4 { color: white; margin-bottom: 14px; font-size: 1rem; font-family: 'Playfair Display', serif; } .footer-col p { font-size: 0.88rem; line-height: 1.6; } .footer-col a { color: rgba(255,255,255,0.68); display: block; margin-bottom: 9px; font-size: 0.88rem; transition: color 0.2s; } .footer-col a:hover { color: var(--accent); } .footer-bottom { border-top: 1px solid rgba(255,255,255,0.13); padding-top: 22px; text-align: center; font-size: 0.82rem; } .hero { background: linear-gradient(135deg, var(--blue-deep) 0%, var(--indigo) 55%, #6c6ab5 100%); color: white; padding: 100px 0 160px; clip-path: polygon(0 0, 100% 0, 100% 84%, 0 100%); position: relative; overflow: hidden; } .hero-content { max-width: 640px; position: relative; z-index: 1; } .hero h1 { font-size: clamp(2.2rem, 5vw, 3.8rem); margin-bottom: 22px; color: white; } .hero p { font-size: 1.1rem; color: rgba(255,255,255,0.83); margin-bottom: 36px; max-width: 500px; line-height: 1.8; } .btn { display: inline-block; background: var(--accent); color: var(--blue-deep); padding: 14px 34px; border-radius: var(--radius); font-weight: 700; font-size: 1rem; transition: transform 0.2s, box-shadow 0.2s; border: none; cursor: pointer; font-family: 'Inter', sans-serif; } .btn:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(245,200,66,0.45); color: var(--blue-deep); } .btn-sm { padding: 10px 22px; font-size: 0.88rem; } .btn-outline { background: transparent; border: 2px solid var(--indigo); color: var(--indigo); } .btn-outline:hover { background: var(--indigo); color: white; } .section-title { text-align: center; font-size: clamp(1.7rem, 3.5vw, 2.6rem); margin-bottom: 52px; position: relative; } .section-title::after { content: ''; display: block; width: 64px; height: 4px; background: var(--accent); margin: 14px auto 0; border-radius: 2px; } .cards-section { padding: 90px 0 70px; } .cards-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 32px; } .card { background: white; border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; transition: transform 0.3s, box-shadow 0.3s; } .card:hover { transform: translateY(-7px); box-shadow: 0 16px 42px rgba(15,27,76,0.17); } .card-img { width: 100%; height: 210px; object-fit: cover; display: block; } .card-body { padding: 30px; } .card-tag { font-size: 0.75rem; font-weight: 700; color: var(--indigo); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 12px; } .card h3 { font-size: 1.25rem; margin-bottom: 14px; } .card p { font-size: 0.92rem; color: var(--text-light); margin-bottom: 20px; line-height: 1.7; } .about-section { background: var(--blue-deep); clip-path: polygon(0 7%, 100% 0, 100% 93%, 0 100%); padding: 130px 0; color: white; } .about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; } .about-text h2 { color: white; font-size: 2.2rem; margin-bottom: 22px; } .about-text p { color: rgba(255,255,255,0.78); margin-bottom: 18px; font-size: 0.97rem; } .about-highlight { background: rgba(245,200,66,0.13); border-left: 4px solid var(--accent); padding: 18px 22px; border-radius: 0 14px 14px 0; margin-top: 28px; color: rgba(255,255,255,0.92); font-style: italic; font-size: 1rem; } .about-img { width: 100%; border-radius: 20px; box-shadow: 0 12px 40px rgba(0,0,0,0.3); display: block; } .subscribe-section { padding: 90px 0; } .subscribe-box { background: white; border-radius: var(--radius); box-shadow: var(--shadow); padding: 52px; max-width: 720px; margin: 0 auto; } .subscribe-box h2 { font-size: 2rem; margin-bottom: 10px; } .subscribe-box > p { color: var(--text-light); margin-bottom: 36px; } .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; } .form-group { display: flex; flex-direction: column; gap: 7px; } .form-group.full { grid-column: 1 / -1; } .form-group label { font-size: 0.85rem; font-weight: 600; color: var(--blue-deep); letter-spacing: 0.3px; } .form-group input { padding: 13px 17px; border: 2px solid #ddddf0; border-radius: 13px; font-size: 0.95rem; outline: none; transition: border-color 0.25s, box-shadow 0.25s; font-family: 'Inter', sans-serif; color: var(--text); background: var(--bg); } .form-group input:focus { border-color: var(--indigo); box-shadow: 0 0 0 3px rgba(61,59,142,0.12); } .form-group input::placeholder { color: #aaa; } .form-submit { margin-top: 6px; } .article-hero { background: linear-gradient(135deg, var(--indigo) 0%, var(--blue-deep) 100%); color: white; padding: 84px 0 130px; clip-path: polygon(0 0, 100% 0, 100% 87%, 0 100%); position: relative; overflow: hidden; } .article-hero-tag { font-size: 0.78rem; font-weight: 700; color: var(--accent); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 18px; } .article-hero h1 { font-size: clamp(1.9rem, 4.5vw, 3rem); color: white; max-width: 820px; position: relative; z-index: 1; } .article-meta { display: flex; gap: 24px; margin-top: 20px; font-size: 0.84rem; color: rgba(255,255,255,0.65); flex-wrap: wrap; } .article-wrap { max-width: 800px; margin: -48px auto 0; background: white; border-radius: var(--radius); box-shadow: var(--shadow); padding: 52px 56px; position: relative; z-index: 2; } .article-wrap h2 { font-size: 1.6rem; margin: 42px 0 18px; color: var(--blue-deep); padding-bottom: 10px; border-bottom: 2px solid var(--bg); } .article-wrap h3 { font-size: 1.2rem; margin: 28px 0 12px; color: var(--indigo); } .article-wrap p { margin-bottom: 20px; color: var(--text); font-size: 0.97rem; line-height: 1.85; } .article-wrap ul { margin: 0 0 20px 26px; } .article-wrap ul li { margin-bottom: 10px; color: var(--text); font-size: 0.95rem; line-height: 1.7; } .article-wrap strong { color: var(--blue-deep); } .comparison-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin: 28px 0; } .comparison-col { background: var(--bg); border-radius: 16px; padding: 22px 26px; } .comparison-col.col-good { border-top: 3px solid #4caf7d; } .comparison-col.col-bad { border-top: 3px solid #e05a5a; } .comparison-col h4 { font-size: 0.95rem; margin-bottom: 14px; } .comparison-col.col-good h4 { color: #2e7d52; } .comparison-col.col-bad h4 { color: #c03535; } .comparison-col ul { list-style: none; padding: 0; margin: 0; } .comparison-col ul li { padding: 8px 0; border-bottom: 1px solid rgba(0,0,0,0.06); font-size: 0.88rem; color: var(--text); display: flex; align-items: flex-start; gap: 8px; } .comparison-col ul li:last-child { border-bottom: none; } .comparison-col.col-good ul li::before { content: '✓'; color: #4caf7d; font-weight: 700; flex-shrink: 0; } .comparison-col.col-bad ul li::before { content: '✗'; color: #e05a5a; font-weight: 700; flex-shrink: 0; } .accent-block { background: linear-gradient(90deg, rgba(61,59,142,0.1), rgba(15,27,76,0.05)); border-left: 4px solid var(--indigo); padding: 20px 24px; border-radius: 0 16px 16px 0; margin: 28px 0; } .accent-block p { margin: 0; color: var(--blue-deep); font-weight: 500; font-style: italic; font-size: 1rem; } .source-note { font-size: 0.8rem; color: #888; margin-top: -14px; margin-bottom: 20px; } .disclaimer { background: #fff9e6; border: 1.5px solid #f5c842; border-radius: 16px; padding: 22px 28px; margin-top: 48px; } .disclaimer-title { font-size: 0.82rem; font-weight: 700; color: var(--indigo); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; } .disclaimer p { margin: 0; font-size: 0.88rem; color: #555; line-height: 1.7; } .policy-hero { background: var(--blue-deep); color: white; padding: 70px 0 100px; clip-path: polygon(0 0, 100% 0, 100% 88%, 0 100%); } .policy-hero h1 { color: white; font-size: 2.4rem; } .policy-hero p { color: rgba(255,255,255,0.65); margin-top: 10px; font-size: 0.9rem; } .policy-wrap { max-width: 820px; margin: -38px auto 0; background: white; border-radius: var(--radius); box-shadow: var(--shadow); padding: 52px 56px; position: relative; z-index: 2; } .policy-wrap h2 { font-size: 1.3rem; margin: 34px 0 12px; color: var(--blue-deep); padding-bottom: 8px; border-bottom: 1px solid var(--bg); } .policy-wrap p { margin-bottom: 14px; color: var(--text); font-size: 0.94rem; line-height: 1.8; } .policy-wrap ul { margin: 0 0 14px 24px; } .policy-wrap ul li { margin-bottom: 7px; color: var(--text); font-size: 0.93rem; } .success-wrap { display: flex; align-items: center; justify-content: center; min-height: 75vh; padding: 60px 0; } .success-box { background: white; border-radius: var(--radius); box-shadow: var(--shadow); padding: 64px 52px; max-width: 520px; text-align: center; } .success-icon { font-size: 3.5rem; margin-bottom: 22px; display: block; } .success-box h1 { font-size: 2.1rem; margin-bottom: 16px; } .success-box p { color: var(--text-light); margin-bottom: 32px; line-height: 1.8; } .notfound-wrap { display: flex; align-items: center; justify-content: center; min-height: 78vh; text-align: center; padding: 60px 0; } .notfound-inner { max-width: 500px; } .notfound-code { font-size: 9rem; font-family: 'Playfair Display', serif; color: var(--indigo); line-height: 1; opacity: 0.25; display: block; } .notfound-inner h2 { font-size: 2rem; margin-bottom: 16px; } .notfound-inner p { color: var(--text-light); margin-bottom: 32px; } #cookie-checkbox { display: none; } .cookie-banner { position: fixed; bottom: 26px; right: 26px; width: 330px; background: white; border-radius: var(--radius); box-shadow: 0 8px 36px rgba(15,27,76,0.22); padding: 26px; z-index: 9999; border-top: 4px solid var(--indigo); transition: transform 0.45s cubic-bezier(0.4,0,0.2,1), opacity 0.45s; } #cookie-checkbox:checked ~ .cookie-banner { transform: translateY(160%); opacity: 0; pointer-events: none; } .cookie-banner h4 { font-size: 1rem; color: var(--blue-deep); margin-bottom: 10px; } .cookie-banner p { font-size: 0.82rem; color: var(--text-light); margin-bottom: 18px; line-height: 1.65; } .cookie-banner label { display: block; background: var(--indigo); color: white; text-align: center; padding: 11px; border-radius: 12px; cursor: pointer; font-weight: 700; font-size: 0.9rem; transition: background 0.2s; } .cookie-banner label:hover { background: var(--blue-deep); } .cookie-link { font-size: 0.77rem; color: var(--indigo); display: block; text-align: center; margin-top: 10px; } @media (max-width: 768px) { .about-grid { grid-template-columns: 1fr; gap: 36px; } .form-grid { grid-template-columns: 1fr; } .comparison-grid { grid-template-columns: 1fr; } .hero { clip-path: polygon(0 0, 100% 0, 100% 94%, 0 100%); padding: 70px 0 110px; } .about-section { clip-path: polygon(0 4%, 100% 0, 100% 96%, 0 100%); padding: 100px 0; } .article-wrap { padding: 32px 22px; margin-top: -28px; } .subscribe-box { padding: 36px 22px; } .policy-wrap { padding: 36px 22px; } .cookie-banner { width: calc(100vw - 32px); right: 16px; bottom: 16px; } .cards-grid { grid-template-columns: 1fr; } }