/* ================================================
   Spinarello – Desert Fiesta / Woven Textile Theme
   ================================================ */

/* --- Design Tokens --- */
:root {
    --c-terracotta: #C1440E;
    --c-terracotta-light: #D4622B;
    --c-rust: #8B3A1A;
    --c-sand: #F5E6D0;
    --c-cream: #FFF8F0;
    --c-cocoa: #2E1A0E;
    --c-cocoa-light: #4A2E1A;
    --c-teal: #3A7D7E;
    --c-teal-dark: #2A5D5E;
    --c-sunset: #E07830;
    --c-burgundy: #6B1D2A;
    --c-warm-white: #FFFAF5;
    --c-border: rgba(193,68,14,.15);
    --c-overlay: rgba(30,20,12,.92);

    --ff: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --fs-base: 1rem;
    --fs-sm: .875rem;
    --fs-xs: .75rem;
    --fs-lg: 1.125rem;
    --fs-xl: 1.5rem;
    --fs-2xl: 2rem;
    --fs-3xl: 2.75rem;
    --fs-hero: clamp(2rem, 5vw, 3.5rem);

    --r-sm: 6px;
    --r-md: 12px;
    --r-lg: 20px;
    --r-xl: 28px;

    --shadow-sm: 0 1px 3px rgba(46,26,14,.08);
    --shadow-md: 0 4px 12px rgba(46,26,14,.1);
    --shadow-lg: 0 8px 30px rgba(46,26,14,.12);
    --shadow-warm: 0 6px 24px rgba(193,68,14,.12);

    --max-w: 1200px;
    --header-h: 64px;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;line-height:1.6}
body{font-family:var(--ff);font-size:var(--fs-base);color:var(--c-cocoa);background:var(--c-cream);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
a{color:var(--c-terracotta);text-decoration:none;transition:color .2s}
a:hover{color:var(--c-rust)}
ul{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4,h5,h6{line-height:1.25;font-weight:700;color:var(--c-cocoa)}

/* --- Utilities --- */
.container{max-width:var(--max-w);margin:0 auto;padding:0 1.25rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--c-terracotta);color:#fff;padding:.5rem 1rem;border-radius:var(--r-sm);z-index:10000;font-size:var(--fs-sm)}
.skip-link:focus{top:.5rem}
.text-center{text-align:center}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:var(--r-md);font-weight:600;font-size:var(--fs-base);transition:all .2s;line-height:1.4}
.btn-primary{background:var(--c-terracotta);color:#fff;box-shadow:var(--shadow-warm)}
.btn-primary:hover{background:var(--c-terracotta-light);color:#fff;transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--c-terracotta);border:2px solid var(--c-terracotta)}
.btn-secondary:hover{background:var(--c-terracotta);color:#fff}
.btn-teal{background:var(--c-teal);color:#fff}
.btn-teal:hover{background:var(--c-teal-dark);color:#fff}
.btn-sm{padding:.5rem 1.25rem;font-size:var(--fs-sm)}

/* --- Woven Pattern Background (CSS-generated) --- */
.woven-bg{position:relative}
.woven-bg::before{content:'';position:absolute;inset:0;opacity:.04;pointer-events:none;background-image:
    repeating-linear-gradient(0deg,transparent,transparent 18px,var(--c-terracotta) 18px,var(--c-terracotta) 19px),
    repeating-linear-gradient(90deg,transparent,transparent 18px,var(--c-terracotta) 18px,var(--c-terracotta) 19px);
    background-size:20px 20px}

/* Diamond pattern overlay */
.diamond-bg{position:relative}
.diamond-bg::before{content:'';position:absolute;inset:0;opacity:.03;pointer-events:none;
    background:repeating-conic-gradient(var(--c-terracotta) 0% 25%,transparent 0% 50%) 0 0/40px 40px}

/* --- Header --- */
.site-header{position:sticky;top:0;z-index:100;background:var(--c-cream);border-bottom:1px solid var(--c-border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}
.logo{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:var(--fs-lg);color:var(--c-cocoa)}
.logo:hover{color:var(--c-terracotta)}
.logo-icon{flex-shrink:0}
.main-nav ul{display:flex;gap:.25rem}
.main-nav a{display:block;padding:.5rem .75rem;border-radius:var(--r-sm);font-size:var(--fs-sm);font-weight:500;color:var(--c-cocoa-light);transition:all .2s}
.main-nav a:hover,.main-nav a.active{color:var(--c-terracotta);background:rgba(193,68,14,.06)}

.header-disclaimer{background:var(--c-cocoa);color:var(--c-sand);font-size:var(--fs-xs);text-align:center;padding:4px 0;letter-spacing:.02em}

.nav-toggle{display:none;width:32px;height:24px;position:relative;z-index:110}
.nav-toggle span{display:block;width:100%;height:2px;background:var(--c-cocoa);border-radius:2px;position:absolute;left:0;transition:all .25s}
.nav-toggle span:nth-child(1){top:0}
.nav-toggle span:nth-child(2){top:50%;transform:translateY(-50%)}
.nav-toggle span:nth-child(3){bottom:0}
.nav-toggle[aria-expanded="true"] span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}

/* --- Hero --- */
.hero{padding:5rem 0 4rem;text-align:center;position:relative;overflow:hidden;
    background:linear-gradient(170deg,#1A0F08 0%,#4A1E10 25%,#C1440E 55%,#E07830 75%,#F5C77F 100%)}
.hero-inner{position:relative;z-index:2}
.hero h1{font-size:var(--fs-hero);color:#fff;margin-bottom:1rem;text-shadow:0 2px 20px rgba(0,0,0,.25)}
.hero .subtitle{font-size:clamp(1rem,2.5vw,1.25rem);color:var(--c-sand);max-width:640px;margin:0 auto 2rem;line-height:1.7}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero .btn-primary{background:#fff;color:var(--c-terracotta);font-size:var(--fs-lg)}
.hero .btn-primary:hover{background:var(--c-sand)}
.hero .btn-secondary{border-color:rgba(255,255,255,.5);color:#fff}
.hero .btn-secondary:hover{background:rgba(255,255,255,.15);border-color:#fff}

/* Hero woven overlay */
.hero::before{content:'';position:absolute;inset:0;opacity:.06;
    background-image:
        repeating-linear-gradient(45deg,transparent,transparent 12px,rgba(255,255,255,.3) 12px,rgba(255,255,255,.3) 13px),
        repeating-linear-gradient(-45deg,transparent,transparent 12px,rgba(255,255,255,.3) 12px,rgba(255,255,255,.3) 13px);
    background-size:18px 18px}

/* Hero dust particles */
.hero-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hero-particles .p{position:absolute;width:3px;height:3px;background:rgba(245,199,127,.5);border-radius:50%;animation:float-up linear infinite}
@keyframes float-up{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:1}90%{opacity:.6}100%{transform:translateY(-10vh) scale(1);opacity:0}}

/* --- Sections --- */
.section{padding:4rem 0}
.section-alt{background:var(--c-sand)}
.section-dark{background:var(--c-cocoa);color:var(--c-sand)}
.section-dark h2,.section-dark h3{color:var(--c-sand)}
.section-header{text-align:center;margin-bottom:3rem}
.section-header h2{font-size:var(--fs-2xl);margin-bottom:.75rem}
.section-header p{font-size:var(--fs-lg);color:var(--c-cocoa-light);max-width:680px;margin:0 auto}

/* Decorative textile border */
.textile-border{position:relative;padding-top:2rem}
.textile-border::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:min(80%,600px);height:4px;
    background:repeating-linear-gradient(90deg,var(--c-terracotta) 0 8px,var(--c-sunset) 8px 16px,var(--c-teal) 16px 24px,var(--c-sand) 24px 32px);border-radius:2px}

/* --- Game Cards --- */
.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.game-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.game-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.game-card-visual{height:160px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.game-card-visual svg{width:64px;height:64px;position:relative;z-index:1}
.game-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.game-card-body h3{font-size:var(--fs-lg);margin-bottom:.5rem}
.game-card-body p{font-size:var(--fs-sm);color:var(--c-cocoa-light);flex:1;margin-bottom:1rem}
.game-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.game-card .badge{display:inline-flex;align-items:center;gap:.25rem;background:rgba(193,68,14,.08);color:var(--c-terracotta);padding:.25rem .5rem;border-radius:var(--r-sm);font-size:var(--fs-xs);font-weight:600}

/* Card visual backgrounds */
.gc-sun{background:linear-gradient(135deg,#F5C77F 0%,#E07830 100%)}
.gc-spin{background:linear-gradient(135deg,#C1440E 0%,#6B1D2A 100%)}
.gc-card{background:linear-gradient(135deg,#3A7D7E 0%,#2A5D5E 100%)}
.gc-symbol{background:linear-gradient(135deg,#8B3A1A 0%,#4A2E1A 100%)}
.gc-tap{background:linear-gradient(135deg,#E07830 0%,#C1440E 100%)}

/* --- Features Grid --- */
.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}
.feature-item{background:#fff;border-radius:var(--r-lg);padding:1.75rem;box-shadow:var(--shadow-sm);border:1px solid var(--c-border)}
.feature-icon{width:48px;height:48px;background:rgba(193,68,14,.08);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.feature-icon svg{width:24px;height:24px;color:var(--c-terracotta)}
.feature-item h3{font-size:var(--fs-base);margin-bottom:.5rem}
.feature-item p{font-size:var(--fs-sm);color:var(--c-cocoa-light)}

/* --- Game Page Layout --- */
.game-page-header{padding:2.5rem 0;text-align:center;
    background:linear-gradient(170deg,#2E1A0E 0%,#4A2E1A 40%,#8B3A1A 100%)}
.game-page-header h1{color:#fff;font-size:var(--fs-2xl);margin-bottom:.5rem}
.game-page-header p{color:var(--c-sand);max-width:600px;margin:0 auto}

.game-wrapper{max-width:800px;margin:0 auto;padding:2rem 1.25rem}
.game-area{background:#fff;border-radius:var(--r-lg);padding:1.5rem;box-shadow:var(--shadow-md);margin-bottom:1.5rem}
.game-disclaimer{background:rgba(193,68,14,.06);border:1px solid var(--c-border);border-radius:var(--r-md);padding:.75rem 1rem;font-size:var(--fs-xs);color:var(--c-cocoa-light);text-align:center;margin-bottom:1.5rem}

.game-controls{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem}
.game-score-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:1rem;background:var(--c-sand);border-radius:var(--r-md);margin-bottom:1.5rem}
.score-item{text-align:center}
.score-item .label{display:block;font-size:var(--fs-xs);color:var(--c-cocoa-light);text-transform:uppercase;letter-spacing:.04em}
.score-item .value{display:block;font-size:var(--fs-xl);font-weight:700;color:var(--c-terracotta)}

.game-board{min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}
.game-instructions{background:var(--c-sand);border-radius:var(--r-md);padding:1.25rem;margin-bottom:1.5rem}
.game-instructions h3{font-size:var(--fs-base);margin-bottom:.5rem}
.game-instructions p,.game-instructions li{font-size:var(--fs-sm);color:var(--c-cocoa-light)}
.game-instructions ol,.game-instructions ul{padding-left:1.25rem}
.game-instructions li{margin-bottom:.25rem;list-style:decimal}

/* --- Page Content --- */
.page-header{padding:3rem 0;text-align:center;
    background:linear-gradient(170deg,#2E1A0E 0%,#4A2E1A 40%,#8B3A1A 100%)}
.page-header h1{color:#fff;font-size:var(--fs-2xl);margin-bottom:.5rem}
.page-header p{color:var(--c-sand)}

.content-section{padding:3rem 0}
.content-section + .content-section{padding-top:0}
.content-wrap{max-width:800px;margin:0 auto}
.content-wrap h2{font-size:var(--fs-xl);margin:2.5rem 0 1rem;padding-top:1rem;border-top:2px solid var(--c-border)}
.content-wrap h2:first-child{border-top:0;padding-top:0;margin-top:0}
.content-wrap h3{font-size:var(--fs-lg);margin:1.5rem 0 .75rem}
.content-wrap p{margin-bottom:1rem;line-height:1.8;color:var(--c-cocoa-light)}
.content-wrap ul,.content-wrap ol{padding-left:1.5rem;margin-bottom:1rem}
.content-wrap li{margin-bottom:.5rem;line-height:1.7;color:var(--c-cocoa-light);list-style:disc}
.content-wrap ol li{list-style:decimal}
.content-wrap strong{color:var(--c-cocoa)}

/* FAQ accordion */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-question{width:100%;text-align:left;padding:1.25rem 2rem 1.25rem 0;font-size:var(--fs-lg);font-weight:600;color:var(--c-cocoa);position:relative;transition:color .2s}
.faq-question::after{content:'+';position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--c-terracotta);transition:transform .2s}
.faq-question[aria-expanded="true"]::after{transform:translateY(-50%) rotate(45deg)}
.faq-question:hover{color:var(--c-terracotta)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-answer-inner{padding:0 0 1.25rem}
.faq-answer-inner p{line-height:1.7;color:var(--c-cocoa-light)}

/* Contact form */
.contact-form{max-width:600px;margin:0 auto}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:600;margin-bottom:.375rem;font-size:var(--fs-sm)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem 1rem;border:1px solid var(--c-border);border-radius:var(--r-md);font:inherit;font-size:var(--fs-base);background:#fff;transition:border-color .2s}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--c-terracotta);box-shadow:0 0 0 3px rgba(193,68,14,.1)}
.form-group textarea{resize:vertical;min-height:120px}

/* --- Age Gate --- */
.age-gate-box{background:var(--c-cream);border-radius:var(--r-xl);padding:2.5rem;max-width:440px;width:90%;text-align:center;box-shadow:var(--shadow-lg)}
.age-gate-icon{margin-bottom:1rem}
.age-gate-box h2{font-size:var(--fs-xl);margin-bottom:.75rem}
.age-gate-box p{font-size:var(--fs-sm);color:var(--c-cocoa-light);margin-bottom:1rem;line-height:1.7}
.age-gate-disclaimer{font-size:var(--fs-xs)!important;background:rgba(193,68,14,.06);padding:.5rem .75rem;border-radius:var(--r-sm);color:var(--c-terracotta)!important;font-weight:500}
.age-gate-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.5rem}

/* --- Footer --- */
.site-footer{background:var(--c-cocoa);color:var(--c-sand);padding:3rem 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:2rem;padding-bottom:2rem}
.footer-brand .logo{color:var(--c-sand);margin-bottom:.75rem}
.footer-brand .logo:hover{color:#fff}
.footer-tagline{font-size:var(--fs-sm);opacity:.75;line-height:1.7}
.footer-links h3{font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem;color:var(--c-sand);opacity:.6}
.footer-links a{display:block;font-size:var(--fs-sm);color:var(--c-sand);padding:.2rem 0;opacity:.8}
.footer-links a:hover{opacity:1;color:#fff}

.footer-responsible{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem 0;border-top:1px solid rgba(255,255,255,.08)}
.footer-responsible p{font-size:var(--fs-xs);opacity:.7;line-height:1.7}
.footer-responsible a{color:var(--c-sand);text-decoration:underline}

.footer-disclaimer{text-align:center;padding:1rem 0;border-top:1px solid rgba(255,255,255,.08);font-size:var(--fs-xs);opacity:.6;letter-spacing:.02em}
.footer-bottom{text-align:center;padding:1rem 0;border-top:1px solid rgba(255,255,255,.05);font-size:var(--fs-xs);opacity:.45}

/* --- CTA Banner --- */
.cta-banner{text-align:center;padding:3rem 1.25rem;
    background:linear-gradient(135deg,var(--c-terracotta) 0%,var(--c-sunset) 100%);border-radius:var(--r-lg);margin:2rem 0}
.cta-banner h2{color:#fff;font-size:var(--fs-xl);margin-bottom:.75rem}
.cta-banner p{color:rgba(255,255,255,.85);margin-bottom:1.5rem}
.cta-banner .btn-primary{background:#fff;color:var(--c-terracotta)}
.cta-banner .btn-primary:hover{background:var(--c-sand)}

/* --- Sun Match --- */
.sun-match-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;max-width:360px;margin:0 auto}
.sun-match-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--c-sand);border:2px solid var(--c-border);border-radius:var(--r-md);cursor:pointer;transition:all .2s;user-select:none}
.sun-match-cell:hover{border-color:var(--c-terracotta)}
.sun-match-cell.selected{border-color:var(--c-terracotta);background:rgba(193,68,14,.1)}
.sun-match-cell.matched{border-color:var(--c-teal);background:rgba(58,125,126,.15)}
.sun-match-cell.miss{border-color:var(--c-rust);background:rgba(139,58,26,.1);opacity:.6}

/* --- Spin Circle --- */
.spin-circle-container{position:relative;width:280px;height:280px;margin:0 auto}
.spin-wheel{width:100%;height:100%;border-radius:50%;position:relative;transition:transform 3s cubic-bezier(.17,.67,.12,.99)}
.spin-pointer{position:absolute;top:-10px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:20px solid var(--c-cocoa);z-index:5}
.spin-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50px;height:50px;background:var(--c-cream);border-radius:50%;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--fs-xs);z-index:3}

/* --- Card Pattern --- */
.card-pattern-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.625rem;max-width:400px;margin:0 auto}
.memory-card{aspect-ratio:3/4;background:var(--c-terracotta);border-radius:var(--r-md);cursor:pointer;transition:transform .3s;transform-style:preserve-3d;position:relative}
.memory-card.flipped{transform:rotateY(180deg)}
.memory-card.matched{opacity:.7;pointer-events:none}
.card-face{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);backface-visibility:hidden}
.card-front{background:var(--c-terracotta);color:#fff;font-size:1.5rem}
.card-front::before{content:'◆';font-size:1.5rem;opacity:.6}
.card-back{background:#fff;border:2px solid var(--c-border);transform:rotateY(180deg);font-size:2rem}

/* --- Daily Symbol --- */
.symbol-picker{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin:1rem 0}
.symbol-btn{width:64px;height:64px;border:2px solid var(--c-border);border-radius:var(--r-md);background:#fff;font-size:1.75rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.symbol-btn:hover{border-color:var(--c-terracotta);background:rgba(193,68,14,.04)}
.symbol-btn.chosen{border-color:var(--c-terracotta);background:rgba(193,68,14,.12)}
.symbol-btn.correct{border-color:var(--c-teal);background:rgba(58,125,126,.15)}
.symbol-btn.wrong{border-color:var(--c-rust);background:rgba(139,58,26,.1)}

.symbol-result{display:flex;gap:.75rem;justify-content:center;margin:1.5rem 0}
.symbol-slot{width:72px;height:72px;border:2px dashed var(--c-border);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:2rem;background:#fff}
.symbol-slot.filled{border-style:solid;border-color:var(--c-terracotta)}

/* --- Rapid Tap --- */
.tap-target{width:120px;height:120px;border-radius:50%;background:var(--c-terracotta);color:#fff;font-size:var(--fs-2xl);font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s,background .1s;user-select:none;box-shadow:var(--shadow-warm)}
.tap-target:active{transform:scale(.92);background:var(--c-rust)}
.tap-target.flash{animation:tap-flash .15s}
@keyframes tap-flash{50%{background:var(--c-sunset);transform:scale(1.05)}}
.tap-progress{width:100%;max-width:400px;height:8px;background:var(--c-sand);border-radius:4px;overflow:hidden;margin:1rem auto}
.tap-progress-bar{height:100%;background:var(--c-terracotta);border-radius:4px;transition:width .1s}

/* --- Responsive --- */
@media (max-width:900px){
    .footer-grid{grid-template-columns:1fr 1fr;gap:1.5rem}
    .footer-brand{grid-column:1/-1}
}
@media (max-width:768px){
    :root{--header-h:56px}
    .nav-toggle{display:block}
    .main-nav{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:var(--c-cream);box-shadow:var(--shadow-lg);padding:5rem 1.5rem 2rem;transition:right .3s;z-index:105;overflow-y:auto}
    .main-nav.open{right:0}
    .main-nav ul{flex-direction:column;gap:0}
    .main-nav a{padding:.75rem .5rem;font-size:var(--fs-base)}
    .hero{padding:3.5rem 0 3rem}
    .section{padding:2.5rem 0}
    .section-header{margin-bottom:2rem}
    .games-grid{grid-template-columns:1fr}
    .card-pattern-grid{grid-template-columns:repeat(3,1fr)}
    .footer-grid{grid-template-columns:1fr}
}
@media (max-width:480px){
    .hero-actions{flex-direction:column;align-items:center}
    .btn{padding:.625rem 1.25rem;font-size:var(--fs-sm)}
    .sun-match-grid{max-width:280px}
}

/* --- Animations --- */
@media (prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
