
/*
Theme Name: moritz.earth Expanded
Theme URI: https://moritz.earth
Author: Moritz
Description: Cleanes Coming-Soon Autoren-Theme für moritz.earth und Route 66.
Version: 2.0
*/

:root{
    --bg:#050505;
    --bg-soft:#0a0d0c;
    --card:#0d1210;
    --line:#1d2b27;
    --text:#f4f1ea;
    --muted:#9aaba4;
    --green:#17483d;
    --green-soft:#b9d8cd;
    --gold:#d7c39b;
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
    margin:0;
    background:
        radial-gradient(circle at 85% 10%, rgba(23,72,61,.34), transparent 32%),
        radial-gradient(circle at 10% 55%, rgba(215,195,155,.10), transparent 30%),
        var(--bg);
    color:var(--text);
    font-family: Inter, Arial, Helvetica, sans-serif;
}

a{color:inherit;text-decoration:none}

.site-header{
    position:fixed;
    top:0;
    left:0;
    right:0;
    z-index:20;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:22px 6vw;
    background:linear-gradient(to bottom, rgba(5,5,5,.82), rgba(5,5,5,.25), transparent);
    backdrop-filter: blur(10px);
}

.brand{
    font-size:18px;
    letter-spacing:.04em;
    font-weight:600;
}

.nav{
    display:flex;
    gap:24px;
    color:var(--muted);
    font-size:14px;
}

.nav a:hover{color:var(--text)}

.hero{
    min-height:100vh;
    display:grid;
    place-items:center;
    padding:130px 6vw 80px;
    position:relative;
    overflow:hidden;
}

.hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:
      linear-gradient(90deg, rgba(5,5,5,.85), rgba(5,5,5,.45)),
      radial-gradient(circle at center, rgba(23,72,61,.18), transparent 45%);
    pointer-events:none;
}

.hero-inner{
    position:relative;
    width:min(1180px,100%);
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:60px;
    align-items:center;
}

.kicker{
    color:var(--green-soft);
    text-transform:uppercase;
    letter-spacing:.22em;
    font-size:13px;
    margin-bottom:18px;
}

h1{
    font-size:clamp(52px,8vw,118px);
    line-height:.92;
    letter-spacing:-.08em;
    margin:0;
    font-weight:700;
}

.hero-title span{
    display:block;
    color:var(--muted);
    font-weight:300;
}

.hero-copy{
    max-width:670px;
    color:#d9ddd8;
    font-size:clamp(18px,2vw,25px);
    line-height:1.55;
    margin:32px 0;
}

.cta-row{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin-top:32px;
}

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:48px;
    padding:0 22px;
    border-radius:999px;
    border:1px solid var(--line);
    background:rgba(255,255,255,.03);
    color:var(--text);
    font-size:14px;
    letter-spacing:.04em;
}

.btn.primary{
    background:var(--text);
    color:#050505;
    border-color:var(--text);
}

.btn:hover{transform:translateY(-1px)}

.book-card{
    border:1px solid var(--line);
    background:linear-gradient(145deg, rgba(13,18,16,.94), rgba(5,5,5,.82));
    border-radius:32px;
    padding:38px;
    min-height:520px;
    box-shadow:0 30px 90px rgba(0,0,0,.38);
    position:relative;
    overflow:hidden;
}

.book-card::after{
    content:"ROUTE 66";
    position:absolute;
    right:-28px;
    bottom:35px;
    transform:rotate(-90deg);
    color:rgba(255,255,255,.06);
    font-size:78px;
    letter-spacing:.08em;
    font-weight:800;
}

.book-label{
    color:var(--gold);
    text-transform:uppercase;
    letter-spacing:.2em;
    font-size:12px;
}

.book-name{
    font-size:72px;
    line-height:.9;
    letter-spacing:-.06em;
    margin:75px 0 20px;
}

.coming-pill{
    display:inline-flex;
    margin-top:20px;
    padding:12px 18px;
    border-radius:999px;
    background:rgba(185,216,205,.08);
    border:1px solid rgba(185,216,205,.2);
    color:var(--green-soft);
    text-transform:uppercase;
    letter-spacing:.16em;
    font-size:12px;
}

.section{
    padding:110px 6vw;
}

.wrap{
    width:min(1120px,100%);
    margin:0 auto;
}

.section-title{
    font-size:clamp(38px,5vw,72px);
    line-height:1;
    letter-spacing:-.06em;
    margin:0 0 28px;
}

.section-lead{
    color:var(--muted);
    font-size:21px;
    line-height:1.7;
    max-width:780px;
}

.grid{
    display:grid;
    gap:22px;
}

.grid.three{grid-template-columns:repeat(3,1fr)}
.grid.two{grid-template-columns:repeat(2,1fr)}

.card{
    border:1px solid var(--line);
    background:rgba(13,18,16,.72);
    border-radius:28px;
    padding:30px;
}

.card h3{
    margin:0 0 16px;
    font-size:24px;
}

.card p{
    margin:0;
    color:var(--muted);
    line-height:1.7;
    font-size:17px;
}

.about-text{
    font-size:20px;
    line-height:1.9;
    color:#dddeda;
    max-width:880px;
}

.about-text p{margin:0 0 24px}

.quote-band{
    padding:110px 6vw;
    background:
      linear-gradient(120deg, rgba(23,72,61,.25), rgba(5,5,5,.9)),
      var(--bg-soft);
    border-block:1px solid var(--line);
}

.big-quote{
    width:min(1050px,100%);
    margin:0 auto;
    font-size:clamp(34px,5vw,78px);
    line-height:1.08;
    letter-spacing:-.055em;
}

.big-quote small{
    display:block;
    margin-top:26px;
    color:var(--muted);
    font-size:16px;
    letter-spacing:.16em;
    text-transform:uppercase;
}

.timeline{
    display:grid;
    gap:16px;
    margin-top:45px;
}

.step{
    display:grid;
    grid-template-columns:110px 1fr;
    gap:28px;
    padding:26px 0;
    border-top:1px solid var(--line);
}

.step strong{
    color:var(--green-soft);
    letter-spacing:.12em;
    text-transform:uppercase;
    font-size:13px;
}

.step p{
    margin:0;
    color:#d9ddd8;
    font-size:20px;
    line-height:1.55;
}

.newsletter{
    text-align:center;
    border:1px solid var(--line);
    border-radius:36px;
    padding:70px 30px;
    background:
      radial-gradient(circle at top, rgba(23,72,61,.25), transparent 55%),
      rgba(13,18,16,.76);
}

.newsletter h2{
    margin:0 0 20px;
    font-size:clamp(38px,5vw,74px);
    letter-spacing:-.06em;
}

.newsletter p{
    max-width:650px;
    margin:0 auto 30px;
    color:var(--muted);
    line-height:1.7;
    font-size:19px;
}

.footer{
    padding:50px 6vw;
    border-top:1px solid var(--line);
    display:flex;
    justify-content:space-between;
    gap:20px;
    color:var(--muted);
    flex-wrap:wrap;
}

@media(max-width:900px){
    .hero-inner,.grid.three,.grid.two{grid-template-columns:1fr}
    .nav{display:none}
    .book-card{min-height:420px}
    .book-name{font-size:56px}
    .step{grid-template-columns:1fr}
    .footer{display:block}
}
