/*
Theme Name: Custom Auto Theme
Author: System
Version: 1.0
*/
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500&display=swap'); *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } :root { --sand: #F5F5F5; --fog: #DCDAD7; --fog-dark: #C8C5C1; --ink: #4A4A4A; --ink-light: #7A7A7A; --ink-xlight: #A8A5A0; --white: #FFFFFF; --radius: 20px; --serif: 'Cormorant Garamond', Georgia, serif; --sans: 'DM Sans', system-ui, sans-serif; } html { scroll-behavior: smooth; font-size: 16px; } body { background: var(--sand); color: var(--ink); font-family: var(--sans); font-weight: 300; line-height: 1.85; -webkit-font-smoothing: antialiased; } header { background: var(--white); padding: 1.25rem 2rem; border-bottom: 1px solid var(--fog); position: sticky; top: 0; z-index: 100; } .header-inner { max-width: 940px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; } .site-logo { font-family: var(--serif); font-size: 1.7rem; font-weight: 600; color: var(--ink); text-decoration: none; letter-spacing: .01em; } nav { display: flex; gap: 2.5rem; } nav a { color: var(--ink-light); text-decoration: none; font-size: .8rem; font-weight: 400; letter-spacing: .1em; text-transform: uppercase; transition: color .25s; } nav a:hover { color: var(--ink); } main { max-width: 940px; margin: 0 auto; padding: 4rem 2rem; } section { margin-bottom: 7rem; } .section-label { font-size: .68rem; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-xlight); margin-bottom: 2.5rem; padding-bottom: .75rem; border-bottom: 1px solid var(--fog); } .hero { position: relative; border-radius: var(--radius); overflow: hidden; min-height: 540px; display: flex; align-items: flex-end; } .hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; } .hero-overlay { position: absolute; inset: 0; background: linear-gradient(160deg, rgba(30,28,26,.08) 0%, rgba(30,28,26,.7) 75%, rgba(30,28,26,.85) 100%); z-index: 1; } .hero-content { position: relative; z-index: 2; padding: 3.5rem; color: var(--white); } .hero-tag { display: inline-block; font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; background: rgba(255,255,255,.15); backdrop-filter: blur(6px); border: 1px solid rgba(255,255,255,.25); padding: .35rem .9rem; border-radius: 50px; margin-bottom: 1.25rem; } .hero h1 { font-family: var(--serif); font-size: clamp(2rem, 4.5vw, 3.2rem); font-weight: 400; font-style: italic; line-height: 1.2; margin-bottom: 1.1rem; max-width: 580px; } .hero p { font-size: .95rem; opacity: .88; max-width: 480px; margin-bottom: 2rem; line-height: 1.75; } .btn { display: inline-block; padding: .8rem 2rem; background: var(--white); color: var(--ink); border-radius: 50px; text-decoration: none; font-family: var(--sans); font-size: .8rem; font-weight: 500; letter-spacing: .05em; text-transform: uppercase; transition: background .3s, transform .2s, box-shadow .3s; border: none; cursor: pointer; } .btn:hover { background: var(--fog); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(74,74,74,.12); } .btn-dark { background: var(--ink); color: var(--white); } .btn-dark:hover { background: #2a2a2a; box-shadow: 0 6px 20px rgba(74,74,74,.25); } .btn-outline { background: transparent; border: 1px solid var(--fog-dark); color: var(--ink); } .btn-outline:hover { background: var(--fog); } .cards-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.75rem; } .card { background: var(--white); border-radius: var(--radius); padding: 2.25rem; text-decoration: none; color: inherit; border: 1px solid var(--fog); transition: transform .35s cubic-bezier(.2,.8,.3,1), box-shadow .35s; display: block; } .card:hover { transform: translateY(-5px); box-shadow: 0 16px 48px rgba(74,74,74,.09); } .card-tag { font-size: .68rem; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-xlight); margin-bottom: .85rem; } .card h3 { font-family: var(--serif); font-size: 1.35rem; font-weight: 400; line-height: 1.38; margin-bottom: .8rem; color: var(--ink); } .card p { font-size: .875rem; color: var(--ink-light); line-height: 1.75; } .main-article { background: var(--white); border-radius: var(--radius); padding: 3.25rem; border: 1px solid var(--fog); } .article-meta { font-size: .7rem; color: var(--ink-xlight); letter-spacing: .12em; text-transform: uppercase; margin-bottom: 2rem; } .main-article h2 { font-family: var(--serif); font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 400; font-style: italic; line-height: 1.3; margin-bottom: 1.5rem; } .main-article p { margin-bottom: 1.35rem; color: #5c5c5c; } .main-article a { color: var(--ink); border-bottom: 1px solid var(--fog-dark); text-decoration: none; transition: border-color .2s; } .main-article a:hover { border-color: var(--ink); } .about-box { background: var(--white); border-radius: var(--radius); padding: 3.5rem; border: 1px solid var(--fog); text-align: center; max-width: 640px; margin: 0 auto; } .about-box h2 { font-family: var(--serif); font-size: 1.8rem; font-weight: 400; font-style: italic; margin-bottom: 1.1rem; } .about-box p { color: var(--ink-light); max-width: 480px; margin: 0 auto; } .subscribe-section { text-align: center; } .subscribe-section > h2 { font-family: var(--serif); font-size: 2rem; font-weight: 400; font-style: italic; margin-bottom: .85rem; } .subscribe-section > p { color: var(--ink-light); margin-bottom: 3rem; } .subscribe-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1rem; max-width: 800px; margin: 0 auto 1.75rem; } .form-input { padding: .9rem 1.4rem; border: 1px solid var(--fog); border-radius: 50px; background: var(--white); color: var(--ink); font-family: var(--sans); font-size: .875rem; font-weight: 300; outline: none; transition: border-color .3s; width: 100%; } .form-input:focus { border-color: var(--ink-light); } .form-input::placeholder { color: var(--ink-xlight); } .form-row { display: flex; justify-content: center; } .article-page-header { margin-bottom: 3rem; } .article-page-header h1 { font-family: var(--serif); font-size: clamp(2.2rem, 5vw, 3.4rem); font-weight: 400; font-style: italic; line-height: 1.18; margin-bottom: 1.1rem; } .article-intro { font-size: 1.1rem; color: var(--ink-light); max-width: 620px; line-height: 1.8; } .article-img { width: 100%; height: 400px; object-fit: cover; border-radius: var(--radius); margin-bottom: 4rem; display: block; } .article-body section { margin-bottom: 3.5rem; } .article-body h2 { font-family: var(--serif); font-size: 1.55rem; font-weight: 400; font-style: italic; margin-bottom: 1.1rem; color: var(--ink); } .article-body p { margin-bottom: 1.35rem; color: #5c5c5c; } .article-body a { color: var(--ink); border-bottom: 1px solid var(--fog-dark); text-decoration: none; } .facts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin: 2.25rem 0; } .fact-item { background: var(--sand); border-radius: var(--radius); padding: 1.75rem; border: 1px solid var(--fog); } .fact-item strong { display: block; font-family: var(--serif); font-size: 1.1rem; font-weight: 400; margin-bottom: .6rem; color: var(--ink); } .fact-item p { font-size: .85rem; color: var(--ink-light); margin: 0; line-height: 1.7; } .disclaimer { background: linear-gradient(135deg, var(--fog) 0%, #E4E1DD 100%); border-radius: var(--radius); padding: 2rem 2.25rem; margin-top: 2.5rem; font-size: .875rem; color: var(--ink-light); line-height: 1.75; border-left: 3px solid var(--fog-dark); } .disclaimer strong { color: var(--ink); } .legal-page h1 { font-family: var(--serif); font-size: 2.4rem; font-weight: 400; font-style: italic; margin-bottom: .5rem; } .legal-updated { font-size: .78rem; color: var(--ink-xlight); margin-bottom: 3.5rem; letter-spacing: .05em; } .legal-page h2 { font-family: var(--serif); font-size: 1.2rem; font-weight: 400; margin: 3rem 0 .85rem; color: var(--ink); } .legal-page p { margin-bottom: 1.1rem; color: #5c5c5c; } .legal-page a { color: var(--ink); } .success-wrap { text-align: center; padding: 7rem 0; } .success-icon { font-size: 2.5rem; margin-bottom: 1.75rem; width: 72px; height: 72px; border-radius: 50%; background: var(--fog); display: flex; align-items: center; justify-content: center; margin: 0 auto 2rem; } .success-wrap h1 { font-family: var(--serif); font-size: 2.2rem; font-weight: 400; font-style: italic; margin-bottom: 1rem; } .success-wrap p { color: var(--ink-light); margin-bottom: 2.5rem; max-width: 440px; margin-left: auto; margin-right: auto; } .error-wrap { text-align: center; padding: 9rem 0; } .error-code { font-family: var(--serif); font-size: 8rem; font-weight: 300; color: var(--fog); line-height: 1; margin-bottom: 1.5rem; letter-spacing: -.05em; } .error-wrap h1 { font-family: var(--serif); font-size: 1.6rem; font-weight: 400; margin-bottom: 1rem; } .error-wrap p { color: var(--ink-light); margin-bottom: 2.5rem; } footer { border-top: 1px solid var(--fog); padding: 3.5rem 2rem 2.5rem; background: var(--white); margin-top: 0; } .footer-inner { max-width: 940px; margin: 0 auto 2.5rem; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 3.5rem; align-items: start; } .footer-brand { font-family: var(--serif); font-size: 1.3rem; font-weight: 400; margin-bottom: .6rem; color: var(--ink); } .footer-desc { font-size: .8rem; color: var(--ink-xlight); line-height: 1.65; } .footer-nav { display: flex; flex-direction: column; gap: .6rem; } .footer-nav h4 { font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-xlight); margin-bottom: .85rem; } .footer-nav a { font-size: .8rem; color: var(--ink-light); text-decoration: none; transition: color .2s; } .footer-nav a:hover { color: var(--ink); } .footer-copy { max-width: 940px; margin: 0 auto; padding-top: 2rem; border-top: 1px solid var(--fog); font-size: .75rem; color: var(--ink-xlight); } .cookie-check { display: none; } .cookie-banner { position: fixed; bottom: 24px; right: 24px; width: 310px; background: var(--white); border-radius: var(--radius); padding: 1.6rem; box-shadow: 0 12px 50px rgba(74,74,74,.14); border: 1px solid var(--fog); z-index: 9999; opacity: 1; transition: opacity .4s ease, transform .4s ease; } .cookie-check:checked ~ .cookie-banner { opacity: 0; pointer-events: none; transform: translateY(10px); } .cookie-banner p { font-size: .8rem; color: var(--ink-light); margin-bottom: 1.1rem; line-height: 1.65; } .cookie-banner a { color: var(--ink); } .cookie-actions { display: flex; gap: .75rem; align-items: center; } .cookie-label { display: inline-block; padding: .55rem 1.4rem; background: var(--ink); color: var(--white); border-radius: 50px; font-size: .78rem; font-family: var(--sans); cursor: pointer; transition: background .2s; letter-spacing: .04em; } .cookie-label:hover { background: #2a2a2a; } .cookie-decline { font-size: .78rem; color: var(--ink-xlight); cursor: pointer; text-decoration: underline; } .reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s cubic-bezier(.2,.8,.3,1), transform .8s cubic-bezier(.2,.8,.3,1); } .reveal.in-view { opacity: 1; transform: none; } .reveal-delay { transition-delay: .15s; } @media (max-width: 768px) { .cards-grid { grid-template-columns: 1fr; } .subscribe-grid { grid-template-columns: 1fr; } .footer-inner { grid-template-columns: 1fr; gap: 2rem; } .facts-grid { grid-template-columns: 1fr; } nav { gap: 1.25rem; } nav a { font-size: .72rem; } main { padding: 2.5rem 1.25rem; } .cookie-banner { width: calc(100% - 2rem); right: 1rem; bottom: 1rem; } .hero { min-height: 420px; } .hero-content { padding: 2rem; } .article-img { height: 240px; } .main-article { padding: 2rem; } .about-box { padding: 2.25rem 1.75rem; } }