/*
Theme Name: Desert Sand
Theme URI: https://example.com/desert-sand
Description: Warm earthy WordPress theme with organic curves, terracotta accents, and a sun-bleached sportsbook feel. Built around natural shapes and soft cream paper.
Version: 1.0
Author: Atelier Dune
Text Domain: desert-sand
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
img{max-width:100%;height:auto;display:block}

:root{
    --ds-sand:#f5e6d3;
    --ds-sand-dark:#e8d3b8;
    --ds-cream:#fefbf6;
    --ds-clay:#c2703f;
    --ds-clay-dark:#a4592e;
    --ds-brown:#3d2b1f;
    --ds-brown-soft:#5a4434;
    --ds-olive:#7a8050;
    --ds-line:#dfcdb4;
    --ds-shadow:0 14px 40px -22px rgba(61,43,31,.4);
}

body{
    font-family:'DM Sans','Helvetica Neue',Arial,sans-serif;
    background:var(--ds-cream);
    color:var(--ds-brown);
    line-height:1.7;
    font-size:16px;
    background-image:
        radial-gradient(circle at 8% 6%,rgba(194,112,63,.10),transparent 40%),
        radial-gradient(circle at 92% 18%,rgba(122,128,80,.08),transparent 35%),
        radial-gradient(circle at 14% 88%,rgba(245,230,211,.5),transparent 50%);
    background-attachment:fixed;
}
body::before{
    content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
    background-image:radial-gradient(rgba(61,43,31,.05) 1px,transparent 1px);
    background-size:18px 18px;opacity:.5;
}

a{color:var(--ds-clay);text-decoration:none;transition:.3s}
a:hover{color:var(--ds-clay-dark)}

h1,h2,h3,h4,h5,h6{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.18;letter-spacing:-.01em;color:var(--ds-brown)}
h1{font-size:54px;font-weight:500}
h2{font-size:38px}
h3{font-size:22px}

.container{max-width:1200px;margin:0 auto;padding:0 28px;position:relative}

/* --- Header (centered brand, nav under) --- */
.site-header{
    background:var(--ds-cream);border-bottom:1px solid var(--ds-line);position:sticky;top:0;z-index:50;
    box-shadow:0 2px 30px -20px rgba(61,43,31,.2);
}
.header-strip{background:var(--ds-brown);color:var(--ds-sand);padding:8px 0;font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.header-strip .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.header-strip a{color:var(--ds-sand)}
.header-strip a:hover{color:var(--ds-clay)}

.brand-row{padding:28px 0 14px;text-align:center;position:relative}
.brand-row::before,.brand-row::after{
    content:"";position:absolute;top:50%;width:120px;height:1px;background:linear-gradient(90deg,transparent,var(--ds-line));
}
.brand-row::before{left:5%}
.brand-row::after{right:5%;background:linear-gradient(-90deg,transparent,var(--ds-line))}
.site-logo{
    font-family:'Fraunces',serif;font-weight:600;font-size:38px;letter-spacing:.02em;
    color:var(--ds-brown);display:inline-flex;align-items:center;gap:14px;
}
.site-logo .glyph{
    width:46px;height:46px;border-radius:50%;
    background:radial-gradient(circle at 30% 30%,#f0a76a,var(--ds-clay) 70%);
    box-shadow:inset 0 -3px 0 rgba(0,0,0,.15),0 6px 14px -6px rgba(194,112,63,.5);
    position:relative;
}
.site-logo .glyph::after{content:"";position:absolute;top:8px;left:8px;width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.6)}
.site-logo em{font-style:italic;color:var(--ds-clay);font-weight:500}
.site-tag{font-size:12px;letter-spacing:.36em;text-transform:uppercase;color:var(--ds-brown-soft);margin-top:6px}

.main-nav{padding:0 0 20px;border-top:1px solid var(--ds-line);margin-top:18px}
.main-nav ul{list-style:none;display:flex;justify-content:center;flex-wrap:wrap;gap:4px;padding-top:16px}
.main-nav li{position:relative}
.main-nav a{
    display:inline-block;padding:10px 18px;color:var(--ds-brown);
    font-size:14px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
    border-radius:99px;transition:.3s;
}
.main-nav a:hover{background:var(--ds-sand);color:var(--ds-clay-dark)}
.main-nav .nav-login a{
    background:var(--ds-clay);color:var(--ds-cream);padding:10px 24px;font-weight:600;
    border:1px solid var(--ds-clay-dark);
    box-shadow:0 6px 16px -8px rgba(194,112,63,.6);
}
.main-nav .nav-login a:hover{background:var(--ds-clay-dark);color:var(--ds-cream)}

.menu-toggle{display:none;background:none;border:1px solid var(--ds-line);color:var(--ds-brown);padding:8px 14px;border-radius:99px;cursor:pointer}

/* --- Hero with curved divider --- */
.hero{
    position:relative;padding:64px 0 100px;
    background:
        radial-gradient(circle at 80% 20%,rgba(194,112,63,.18),transparent 50%),
        linear-gradient(180deg,var(--ds-sand) 0%,#efd9be 100%);
    overflow:hidden;
}
.hero::before{
    content:"";position:absolute;top:-60px;right:-60px;width:280px;height:280px;border-radius:50%;
    background:radial-gradient(circle at 30% 30%,#f6c89a,var(--ds-clay));
    opacity:.45;filter:blur(2px);
}
.hero::after{
    content:"";position:absolute;bottom:-1px;left:0;right:0;height:90px;
    background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 90' preserveAspectRatio='none'><path d='M0,90 C300,10 900,10 1200,90 L1200,90 L0,90 Z' fill='%23fefbf6'/></svg>") no-repeat center bottom/cover;
}
.hero .container{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:6px 14px;background:rgba(255,251,246,.6);border:1px solid var(--ds-line);border-radius:99px;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ds-brown-soft);margin-bottom:18px}
.hero-eyebrow .pip{width:8px;height:8px;border-radius:50%;background:var(--ds-clay)}
.hero h1{font-size:62px;line-height:1.05;margin-bottom:18px}
.hero h1 em{font-style:italic;color:var(--ds-clay)}
.hero p{font-size:18px;color:var(--ds-brown-soft);max-width:540px;margin-bottom:30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{
    display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:99px;
    background:var(--ds-clay);color:var(--ds-cream);font-weight:600;letter-spacing:.05em;
    border:1px solid var(--ds-clay-dark);box-shadow:0 10px 24px -10px rgba(194,112,63,.6);
    transition:.3s;
}
.btn-primary:hover{background:var(--ds-clay-dark);color:var(--ds-cream);transform:translateY(-2px)}
.btn-ghost{
    display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border-radius:99px;
    background:transparent;color:var(--ds-brown);border:1px solid var(--ds-brown);
    font-weight:500;letter-spacing:.05em;transition:.3s;
}
.btn-ghost:hover{background:var(--ds-brown);color:var(--ds-cream)}

.hero-card{
    background:var(--ds-cream);border:1px solid var(--ds-line);border-radius:24px;padding:28px;
    box-shadow:var(--ds-shadow);position:relative;
}
.hero-card::before{
    content:"";position:absolute;top:-18px;left:24px;width:48px;height:48px;border-radius:50%;
    background:var(--ds-clay);box-shadow:0 6px 16px -6px rgba(194,112,63,.6);
}
.hero-card::after{content:"\2600";position:absolute;top:-10px;left:36px;color:var(--ds-cream);font-size:24px;line-height:1}
.hero-card h3{font-size:20px;margin-bottom:18px;padding-top:6px}
.odds-list{display:flex;flex-direction:column;gap:10px}
.odds-list-row{
    display:grid;grid-template-columns:1fr auto;align-items:center;gap:14px;
    padding:14px 16px;background:var(--ds-sand);border-radius:14px;border:1px solid var(--ds-sand-dark);
}
.odds-list-row strong{font-size:14px;font-weight:600;color:var(--ds-brown)}
.odds-list-row small{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ds-brown-soft);margin-top:2px}
.odds-list-row .v{font-family:'Fraunces',serif;font-size:20px;color:var(--ds-clay-dark);font-weight:600;background:var(--ds-cream);padding:6px 14px;border-radius:10px;border:1px solid var(--ds-line)}

/* --- Sections --- */
.section{padding:64px 0;position:relative}
.section--alt{background:linear-gradient(180deg,var(--ds-cream),var(--ds-sand) 100%)}
.section-head{text-align:center;max-width:680px;margin:0 auto 42px}
.section-head .eyebrow{display:inline-block;font-size:12px;letter-spacing:.36em;text-transform:uppercase;color:var(--ds-clay);margin-bottom:10px}
.section-head h2{font-size:42px;margin-bottom:10px}
.section-head h2 em{font-style:italic;color:var(--ds-clay)}
.section-head p{color:var(--ds-brown-soft);font-size:16px}

/* --- Latest news cards (3 col rounded) --- */
.layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:48px;align-items:flex-start}
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{
    background:var(--ds-cream);border:1px solid var(--ds-line);border-radius:22px;overflow:hidden;
    display:flex;flex-direction:column;transition:.3s;box-shadow:0 6px 30px -22px rgba(61,43,31,.3);
}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--ds-shadow);border-color:var(--ds-clay)}
.post-card .thumb{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--ds-sand)}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;transition:.6s}
.post-card:hover .thumb img{transform:scale(1.05)}
.post-card .thumb .fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--ds-clay);font-size:48px;font-family:'Fraunces',serif}
.post-card .thumb .cat{position:absolute;top:14px;left:14px;background:var(--ds-cream);color:var(--ds-brown);padding:6px 14px;border-radius:99px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--ds-line)}
.post-card .body{padding:22px 22px 8px;flex:1;display:flex;flex-direction:column}
.post-card .date{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ds-brown-soft);margin-bottom:8px}
.post-card h3{font-size:21px;line-height:1.25;margin-bottom:10px}
.post-card h3 a{color:var(--ds-brown)}
.post-card h3 a:hover{color:var(--ds-clay)}
.post-card .excerpt{color:var(--ds-brown-soft);font-size:14px;flex:1}
.post-card .footer{padding:14px 22px 22px;border-top:1px dashed var(--ds-line);margin-top:14px}
.post-card .read-more{font-size:13px;letter-spacing:.06em;color:var(--ds-clay-dark);font-weight:600;display:inline-flex;gap:6px;align-items:center}
.post-card .read-more:hover{color:var(--ds-brown)}

/* --- Sidebar --- */
.sidebar{display:flex;flex-direction:column;gap:22px;position:sticky;top:200px}
.widget{
    background:var(--ds-cream);border:1px solid var(--ds-line);border-radius:22px;padding:26px;
    position:relative;
}
.widget::before{
    content:"";position:absolute;top:-6px;left:26px;width:32px;height:12px;border-radius:99px 99px 0 0;
    background:var(--ds-clay);
}
.widget-title{font-size:13px;letter-spacing:.28em;text-transform:uppercase;color:var(--ds-brown-soft);margin-bottom:14px}
.widget ul{list-style:none}
.widget ul li{padding:10px 0;border-bottom:1px dashed var(--ds-line);font-size:14px}
.widget ul li:last-child{border-bottom:0}
.widget ul li a{display:flex;justify-content:space-between;align-items:center;gap:10px;color:var(--ds-brown)}
.widget ul li a:hover{color:var(--ds-clay)}
.widget ul li span{font-family:'Fraunces',serif;color:var(--ds-clay);font-size:14px;font-weight:500}
.widget .promo{padding:18px;background:var(--ds-sand);border-radius:14px;text-align:center;border:1px dashed var(--ds-clay)}
.widget .promo p{color:var(--ds-brown-soft);font-size:13px;margin-bottom:14px}

/* --- Breadcrumb --- */
.breadcrumb{padding:18px 0;border-bottom:1px solid var(--ds-line);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ds-brown-soft);background:var(--ds-cream)}
.breadcrumb a{color:var(--ds-clay)}
.breadcrumb .sep{margin:0 10px;color:var(--ds-line)}

/* --- Single --- */
.single-article{background:var(--ds-cream);border:1px solid var(--ds-line);border-radius:24px;padding:36px;box-shadow:0 12px 40px -28px rgba(61,43,31,.3)}
.single-article .featured{border-radius:18px;overflow:hidden;margin-bottom:28px;max-height:480px}
.single-article h1{font-size:46px;margin-bottom:14px}
.post-meta{display:flex;flex-wrap:wrap;gap:14px;color:var(--ds-brown-soft);font-size:13px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:24px;padding-bottom:18px;border-bottom:1px dashed var(--ds-line)}
.post-meta span+span::before{content:"\2022";color:var(--ds-clay);margin-right:14px}
.post-body{font-size:17px;line-height:1.85;color:var(--ds-brown-soft)}
.post-body p,.post-body ul,.post-body ol{margin-bottom:18px}
.post-body h2,.post-body h3{margin:28px 0 14px;color:var(--ds-brown)}
.post-body a{color:var(--ds-clay);text-decoration:underline;text-underline-offset:3px}
.post-tags{margin-top:22px;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.post-tags a{display:inline-block;padding:5px 12px;border:1px solid var(--ds-line);border-radius:99px;margin-right:6px;color:var(--ds-brown-soft)}
.post-tags a:hover{background:var(--ds-sand)}

.related{margin-top:48px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

/* --- Archive --- */
.archive-hero{padding:56px 0 32px;text-align:center;background:linear-gradient(180deg,var(--ds-sand),transparent)}
.archive-hero .eyebrow{display:inline-block;font-size:12px;letter-spacing:.36em;text-transform:uppercase;color:var(--ds-clay);margin-bottom:8px}
.archive-hero h1{font-size:48px}
.archive-hero p{color:var(--ds-brown-soft);max-width:620px;margin:8px auto 0}

.pagination{margin-top:36px;display:flex;justify-content:center}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 14px;border:1px solid var(--ds-line);color:var(--ds-brown);margin:0 4px;border-radius:99px;font-family:'Fraunces',serif;font-size:14px;background:var(--ds-cream)}
.pagination .page-numbers.current,.pagination .page-numbers:hover{background:var(--ds-clay);color:var(--ds-cream);border-color:var(--ds-clay)}

/* --- Comments --- */
.comments-area{margin-top:36px;background:var(--ds-cream);border:1px solid var(--ds-line);border-radius:22px;padding:30px}
.comments-area h2{font-size:24px;margin-bottom:20px}
.comment-list{list-style:none}
.comment-list li{padding:14px 0;border-bottom:1px dashed var(--ds-line)}
.comment-form input,.comment-form textarea{width:100%;padding:12px 16px;background:var(--ds-cream);border:1px solid var(--ds-line);color:var(--ds-brown);border-radius:14px;margin-bottom:12px;font-family:inherit}
.comment-form input:focus,.comment-form textarea:focus{outline:none;border-color:var(--ds-clay)}
.comment-form .submit{background:var(--ds-clay);color:var(--ds-cream);border:0;padding:12px 24px;border-radius:99px;font-weight:600;cursor:pointer;letter-spacing:.06em}

/* --- 404 --- */
.notfound{padding:120px 0;text-align:center}
.notfound .num{font-family:'Fraunces',serif;font-size:170px;color:var(--ds-clay);font-weight:300;font-style:italic;line-height:1;margin-bottom:16px}
.notfound h1{font-size:36px;margin-bottom:12px}
.notfound p{color:var(--ds-brown-soft);margin-bottom:26px;max-width:540px;margin-inline:auto}

/* --- Footer --- */
.site-footer{margin-top:64px;background:var(--ds-brown);color:var(--ds-sand);padding:60px 0 0;position:relative}
.site-footer::before{
    content:"";position:absolute;top:-1px;left:0;right:0;height:60px;
    background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 60' preserveAspectRatio='none'><path d='M0,0 C300,60 900,60 1200,0 L1200,0 L0,0 Z' fill='%23fefbf6'/></svg>") no-repeat center top/cover;
}
.site-footer .grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:32px;padding:42px 0}
.site-footer h3{color:var(--ds-cream);font-size:20px;margin-bottom:16px}
.site-footer ul{list-style:none}
.site-footer li{padding:5px 0}
.site-footer li a{color:var(--ds-sand);font-size:14px}
.site-footer li a:hover{color:var(--ds-clay)}
.site-footer p{color:var(--ds-sand);font-size:14px;opacity:.85}
.footer-bottom{border-top:1px solid rgba(245,230,211,.18);padding:18px 0;text-align:center;font-size:13px;letter-spacing:.16em;text-transform:uppercase;opacity:.7}

@media(max-width:1024px){
    .hero .container{grid-template-columns:1fr}
    .layout{grid-template-columns:1fr}
    .sidebar{position:static}
    .posts-grid,.related-grid{grid-template-columns:1fr 1fr}
    .site-footer .grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
    h1{font-size:36px}
    .menu-toggle{display:inline-flex;position:absolute;right:20px;top:30px}
    .main-nav{display:none}
    .hero h1{font-size:42px}
    .posts-grid,.related-grid{grid-template-columns:1fr}
    .site-footer .grid{grid-template-columns:1fr}
}
