/*
Theme Name: Spin the Wheel
Theme URI: https://example.com/spin-the-wheel
Author: Spin the Wheel
Author URI: https://example.com
Description: Spin the Wheel — a ready-to-use, fully customizable WordPress theme for a picker wheel / random picker wheel / random name picker wheel / name picker wheel / random name picker / wheel spin / pickerwheel / spin wheel / wheel decide / wheel of names / spin the wheel / wheel spinner / random wheel / randomizer wheel / spinner wheel / spinning wheel / random picker website. Built with strong performance, on-page SEO, Schema.org data, semantic HTML5, and a built-in multi-language switcher (English, Arabic, Spanish, German, Italian, French, Chinese).
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Tested up to: 6.6
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: spin-the-wheel
Tags: custom-background, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready, block-styles, one-column, two-columns, right-sidebar, accessibility-ready
*/

/* ==========================================================================
   0. Design tokens
   ========================================================================== */
:root{
  --primary:#f43f2e;
  --primary-2:#ff8a3d;
  --secondary:#0f172a;
  --muted-bg:#f8fafc;
  --muted-fg:#64748b;
  --border:#e5e7eb;
  --accent-bg:#fff4ec;
  --accent-fg:#d94a1f;
  --white:#ffffff;
  --radius:0.9rem;
  --brand-grad:linear-gradient(135deg,#ff8a3d 0%,#f43f2e 100%);
  --navy-grad:linear-gradient(135deg,#1e293b 0%,#2743a5 100%);
  --shadow-sm:0 1px 2px rgba(15,23,42,.06);
  --shadow-md:0 10px 40px -20px rgba(0,0,0,.25);
  --shadow-lg:0 20px 45px -20px rgba(0,0,0,.25);
  --container:72rem;
  --container-wide:90rem;
}

/* ==========================================================================
   1. Reset & base
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--secondary);
  background:#fafafa;
  overflow-x:clip;
  line-height:1.6;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
ul,ol{margin:0;padding:0}
h1,h2,h3,h4,.font-display{font-family:"Poppins","Inter",sans-serif;line-height:1.25;margin:0}
p{margin:0}
input,textarea{font-family:inherit;font-size:.9rem}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px}

.skip-link{position:absolute;left:-999px;top:0;background:#fff;color:#000;padding:.6rem 1rem;z-index:9999}
.skip-link:focus{left:0}

.screen-reader-text{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}

/* Layout helpers */
.container{max-width:var(--container-wide);margin:0 auto;padding:0 1rem}
.section{max-width:var(--container);margin:0 auto;padding:4rem 1rem}
.section--narrow{max-width:48rem}
.text-center{text-align:center}
@media(min-width:768px){.section{padding:4rem 2rem}.container{padding:0 2rem}}

.eyebrow{display:inline-block;border-radius:999px;background:var(--accent-bg);color:var(--primary);padding:.3rem .9rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.section-title{margin-top:1rem;font-size:1.9rem;font-weight:800;color:var(--secondary)}
@media(min-width:768px){.section-title{font-size:2.3rem}}
.section-subtitle{margin:.75rem auto 0;max-width:42rem;color:var(--muted-fg)}
.text-brand-gradient{background-image:var(--brand-grad);-webkit-background-clip:text;background-clip:text;color:transparent}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border-radius:.9rem;padding:.75rem 1.4rem;font-weight:600;font-size:.9rem;border:none;transition:.2s;cursor:pointer}
.btn-primary{background-image:var(--brand-grad);color:#fff}
.btn-primary:hover{transform:scale(1.04)}
.btn-outline{border:1px solid var(--border);background:#fff;color:var(--secondary)}
.btn-outline:hover{background:var(--muted-bg)}
.btn-full{width:100%}

.card{border:1px solid var(--border);background:#fff;border-radius:1.1rem;box-shadow:var(--shadow-sm)}
.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card{transition:.2s}

/* ==========================================================================
   2. Header
   ========================================================================== */
.site-header{position:sticky;top:0;z-index:50;width:100%;background:#fff;border-bottom:1px solid transparent;transition:.2s}
.site-header.is-scrolled{border-color:var(--border);background:rgba(255,255,255,.92);backdrop-filter:blur(6px)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem}
@media(min-width:768px){.site-header .container{padding:.7rem 2rem}}
.brand{display:flex;align-items:center;gap:.5rem}
.brand-mark{display:flex;height:2.3rem;width:2.3rem;align-items:center;justify-content:center;border-radius:.8rem;background-image:var(--brand-grad);color:#fff;box-shadow:var(--shadow-sm)}
.brand-name{font-family:"Poppins",sans-serif;font-size:1.25rem;font-weight:800;color:var(--secondary)}
.brand-badge{border-radius:999px;background:#dcfce7;color:#15803d;padding:.1rem .5rem;font-size:.62rem;font-weight:700;text-transform:uppercase}

.primary-nav{display:none;align-items:center;gap:1.5rem}
.primary-nav ul{display:flex;gap:1.5rem;list-style:none}
.primary-nav a{font-size:.9rem;font-weight:500;color:var(--secondary);transition:.15s}
.primary-nav a:hover,.primary-nav .current-menu-item>a{color:var(--primary)}
@media(min-width:1024px){.primary-nav{display:flex}}

.header-actions{display:flex;align-items:center;gap:.6rem}
.menu-toggle{display:inline-flex;border:1px solid var(--border);border-radius:.6rem;padding:.45rem;background:#fff}
@media(min-width:1024px){.menu-toggle{display:none}}
.header-cta{display:none}
@media(min-width:640px){.header-cta{display:inline-flex}}

.mobile-nav{display:none;border-top:1px solid var(--border);background:#fff;padding:.75rem 1rem}
.mobile-nav.is-open{display:block}
.mobile-nav ul{list-style:none;display:flex;flex-direction:column}
.mobile-nav a{display:block;border-radius:.6rem;padding:.6rem .8rem;font-size:.9rem;font-weight:500;color:var(--secondary)}
.mobile-nav .current-menu-item>a{background:var(--accent-bg);color:var(--primary)}
.mobile-nav .btn{margin-top:.5rem;width:100%}

/* ==========================================================================
   Language switcher
   ========================================================================== */
.stw-lang-switcher{position:relative}
.stw-lang-current{display:inline-flex;align-items:center;gap:.4rem;border:1px solid var(--border);border-radius:.6rem;padding:.45rem .7rem;background:#fff;font-size:.85rem;font-weight:500;color:var(--secondary);cursor:pointer}
.stw-lang-current:hover{border-color:var(--primary);color:var(--primary)}
.stw-lang-menu{position:absolute;inset-inline-end:0;top:calc(100% + .4rem);z-index:40;list-style:none;margin:0;padding:.4rem;min-width:9.5rem;background:#fff;border:1px solid var(--border);border-radius:.7rem;box-shadow:0 12px 28px rgba(15,23,42,.12)}
.stw-lang-menu[hidden]{display:none}
.stw-lang-menu li{margin:0}
.stw-lang-menu a{display:block;border-radius:.5rem;padding:.45rem .6rem;font-size:.85rem;color:var(--secondary);text-decoration:none}
.stw-lang-menu a:hover{background:var(--accent-bg);color:var(--primary)}
.stw-lang-menu a.is-active{color:var(--primary);font-weight:600}
.stw-lang-switcher-mobile{margin-top:.75rem}
.stw-lang-switcher-mobile .stw-lang-menu{position:static;box-shadow:none;margin-top:.4rem}
html[dir="rtl"] .stw-lang-menu{inset-inline-end:auto;inset-inline-start:0}

/* ==========================================================================
   3. Hero + wheel tool
   ========================================================================== */
.hero{max-width:var(--container-wide);margin:0 auto;padding:2.4rem 1rem 1rem}
@media(min-width:768px){.hero{padding:2.4rem 2rem 1rem}}
.hero-head{text-align:center;margin-bottom:2rem}
.hero h1{margin:1rem auto 0;max-width:44rem;font-size:2.2rem;font-weight:800;color:var(--secondary)}
@media(min-width:768px){.hero h1{font-size:3rem}}
.hero p{margin:.75rem auto 0;max-width:34rem;color:var(--muted-fg)}

.wheel-tool{display:grid;gap:1.5rem;align-items:start;max-width:64rem;margin:0 auto}
@media(min-width:900px){.wheel-tool{grid-template-columns:1fr 22rem}}

.wheel-panel{display:flex;flex-direction:column;align-items:center;gap:1.25rem}
.wheel-wrap{position:relative;width:100%;max-width:380px}
.wheel-pointer{position:absolute;left:50%;top:-4px;z-index:20;transform:translateX(-50%);filter:drop-shadow(0 2px 3px rgba(0,0,0,.25))}
.wheel-ring{border-radius:999px;padding:.5rem;box-shadow:0 20px 60px -15px rgba(244,63,46,.45);background-image:linear-gradient(135deg,#ff8a3d,#f43f2e)}
.wheel-svg{display:block;width:100%;border-radius:999px;background:#fff}
.wheel-svg.is-spinning{transition:transform 4.2s cubic-bezier(.17,.67,.16,.99)}
.wheel-spin-btn{position:absolute;left:50%;top:50%;z-index:20;transform:translate(-50%,-50%);display:flex;height:5rem;width:5rem;align-items:center;justify-content:center;border-radius:999px;border:4px solid #fff;background-image:var(--brand-grad);font-family:"Poppins",sans-serif;font-weight:800;font-size:.85rem;color:#fff;box-shadow:var(--shadow-lg);transition:.15s}
.wheel-spin-btn:hover:not(:disabled){transform:translate(-50%,-50%) scale(1.05)}
.wheel-spin-btn:disabled{opacity:.6;cursor:not-allowed}

.wheel-toolbar{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}
.wheel-toolbar button{display:inline-flex;align-items:center;gap:.35rem;border:1px solid var(--border);background:#fff;border-radius:.7rem;padding:.4rem .8rem;font-size:.8rem;font-weight:600;color:var(--secondary)}
.wheel-winner{min-height:2.5rem;text-align:center;font-weight:700;color:var(--secondary)}
.wheel-winner b{background-image:var(--brand-grad);-webkit-background-clip:text;background-clip:text;color:transparent}

.wheel-options-panel{border:1px solid var(--border);background:#fff;border-radius:1.1rem;padding:1.25rem;box-shadow:var(--shadow-md)}
.wheel-options-panel h3{font-size:1.05rem;font-weight:800}
.option-form{display:flex;gap:.5rem;margin-top:1rem}
.option-form input{flex:1;min-width:0;border:1px solid var(--border);border-radius:.8rem;padding:.6rem .75rem;font-size:.85rem}
.option-form input:focus{border-color:var(--primary)}
.option-hint{margin-top:.4rem;font-size:.75rem;color:var(--muted-fg)}

.option-list{margin-top:1rem;max-height:19rem;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding-right:.2rem}
.option-row{display:flex;align-items:center;gap:.5rem;border:1px solid var(--border);background:#f8fafc;border-radius:.8rem;padding:.45rem .55rem}
.option-row.dragging{opacity:.5}
.option-grip{cursor:grab;color:var(--muted-fg);flex-shrink:0}
.option-color{width:1.2rem;height:1.2rem;border-radius:999px;box-shadow:0 0 0 2px #fff;flex-shrink:0;border:none;padding:0}
.color-popover{position:absolute;z-index:30;margin-top:.4rem;display:flex;flex-wrap:wrap;gap:.35rem;width:9.5rem;border:1px solid var(--border);background:#fff;border-radius:.8rem;padding:.5rem;box-shadow:var(--shadow-lg)}
.color-popover button{width:1.2rem;height:1.2rem;border-radius:999px;border:none;padding:0}
.option-label-input{flex:1;min-width:0;border:none;background:transparent;font-size:.85rem;color:var(--secondary)}
.option-weight{width:2.6rem;border:1px solid var(--border);border-radius:.4rem;background:#fff;padding:.15rem;text-align:center;font-size:.75rem}
.option-remove{border:none;background:none;color:var(--muted-fg);flex-shrink:0}
.option-remove:hover{color:var(--primary)}
.empty-options{padding:1.2rem 0;text-align:center;font-size:.85rem;color:var(--muted-fg)}
.labels-toggle{margin-top:1rem;display:flex;align-items:center;gap:.5rem;font-size:.85rem}
.panel-footer{margin-top:.75rem;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);padding-top:.75rem;font-size:.75rem;color:var(--muted-fg)}
.panel-footer .link-danger{color:#e11d48;font-weight:600}
.panel-warning{margin-top:.5rem;border-radius:.6rem;background:#fffbeb;color:#b45309;padding:.4rem .6rem;font-size:.75rem}

/* Spin counter */
.spin-counter{margin:1.5rem auto;width:fit-content;border-radius:1.1rem;padding:1.1rem 2rem;text-align:center;background-image:var(--navy-grad);box-shadow:var(--shadow-lg)}
.spin-counter p{font-size:.65rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.spin-counter .digits{display:flex;justify-content:center;gap:.4rem;margin:.5rem 0}
.spin-counter .digit{display:flex;height:3rem;width:2.2rem;align-items:center;justify-content:center;border-radius:.4rem;background:rgba(0,0,0,.3);font-family:monospace;font-size:1.4rem;font-weight:700;color:var(--primary-2)}
.spin-counter .btn-primary{padding:.4rem 1rem;font-size:.75rem;border-radius:999px}

/* ==========================================================================
   4. Feature grids / generic sections
   ========================================================================== */
.grid{display:grid;gap:1.25rem}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
@media(min-width:640px){.grid-2{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.grid-3{grid-template-columns:1fr 1fr 1fr}}

.feature-card{padding:1.5rem;text-align:left}
.feature-icon{display:flex;height:2.75rem;width:2.75rem;align-items:center;justify-content:center;border-radius:.8rem;background:var(--accent-bg);color:var(--primary)}
.feature-card h3{margin-top:1rem;font-size:1rem;font-weight:700}
.feature-card p{margin-top:.4rem;font-size:.88rem;color:var(--muted-fg)}

.navy-box{border-radius:1.5rem;background-image:var(--navy-grad);color:#fff;padding:2rem}
@media(min-width:768px){.navy-box{padding:3rem}}
.navy-box h3{font-size:1.5rem;font-weight:800}
.navy-box .grid{margin-top:2rem}
.navy-item{display:flex;gap:.75rem}
.navy-check{margin-top:.15rem;display:flex;height:1.5rem;width:1.5rem;flex-shrink:0;align-items:center;justify-content:center;border-radius:999px;background-image:var(--brand-grad);color:#fff}
.navy-item p:first-child{font-weight:600}
.navy-item p:last-child{font-size:.85rem;color:rgba(255,255,255,.7)}

.compare-table{width:100%;border-collapse:collapse;margin-top:1.5rem;font-size:.85rem}
.compare-table th,.compare-table td{border:1px solid var(--border);padding:.65rem .75rem;text-align:center}
.compare-table thead th{background:var(--secondary);color:#fff}
.compare-table td:first-child,.compare-table th:first-child{text-align:left;font-weight:600}
.compare-table tbody tr:nth-child(odd){background:#fff}
.compare-table tbody tr:nth-child(even){background:var(--muted-bg)}

.guide-card{padding:1.5rem;text-align:left}
.guide-card h3{font-weight:700}
.guide-card .kicker{margin-top:1rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary)}
.guide-card ul{margin-top:.5rem;display:flex;flex-direction:column;gap:.4rem;font-size:.88rem}
.guide-card ul li{display:flex;gap:.5rem}
.check-ico{color:#16a34a;flex-shrink:0}

.faq details{border:1px solid var(--border);background:#fff;border-radius:.9rem;padding:.2rem 1rem;margin-bottom:.7rem}
.faq summary{cursor:pointer;padding:.8rem 0;font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:.5rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.2rem;color:var(--primary)}
.faq details[open] summary::after{content:"–"}
.faq p{padding:0 0 1rem;color:var(--muted-fg)}

.occasion-card{padding:1.5rem;text-align:left}
.occasion-card h3{margin-top:1rem;font-weight:700}
.occasion-card p{margin-top:.35rem;font-size:.88rem;color:var(--muted-fg)}
.occasion-card .kicker{margin-top:1rem;font-size:.7rem;font-weight:700;text-transform:uppercase;color:var(--muted-fg)}
.occasion-card ul{margin-top:.4rem;font-size:.85rem;display:flex;flex-direction:column;gap:.25rem}

.steps{display:grid;gap:2rem;grid-template-columns:1fr}
@media(min-width:640px){.steps{grid-template-columns:1fr 1fr 1fr}}
.step{display:flex;flex-direction:column;align-items:center;text-align:center}
.step-badge{position:relative;display:flex;height:3.5rem;width:3.5rem;align-items:center;justify-content:center;border-radius:999px;background-image:var(--brand-grad);color:#fff}
.step-num{position:absolute;right:-.25rem;top:-.25rem;display:flex;height:1.5rem;width:1.5rem;align-items:center;justify-content:center;border-radius:999px;background:var(--secondary);color:#fff;font-size:.7rem;font-weight:700}
.step h3{margin-top:1rem;font-weight:700}
.step p{margin-top:.25rem;font-size:.85rem;color:var(--muted-fg);max-width:16rem}

.template-mini{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media(min-width:640px){.template-mini{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.template-mini{grid-template-columns:repeat(5,1fr)}}
.template-mini a{padding:1.1rem;text-align:center}
.template-mini .dice{margin:0 auto;display:flex;height:2.4rem;width:2.4rem;align-items:center;justify-content:center;border-radius:999px;background-image:var(--brand-grad);color:#fff}
.template-mini p{margin-top:.6rem;font-size:.85rem;font-weight:600}

/* ==========================================================================
   5. Templates page
   ========================================================================== */
.filter-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:2rem}
.filter-bar button{border-radius:999px;padding:.5rem 1.1rem;font-size:.85rem;font-weight:600;border:1px solid var(--border);background:#fff;color:var(--secondary)}
.filter-bar button.is-active{background-image:var(--brand-grad);color:#fff;border-color:transparent}
.templates-grid{display:grid;gap:1.25rem;grid-template-columns:1fr;margin-top:2.5rem}
@media(min-width:640px){.templates-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.templates-grid{grid-template-columns:1fr 1fr 1fr}}
.template-card{display:flex;flex-direction:column;padding:1.5rem}
.template-card h3{margin-top:1rem;font-weight:700}
.template-card p{margin-top:.35rem;font-size:.88rem;color:var(--muted-fg);flex:1}
.template-meta{margin-top:.5rem;font-size:.75rem;color:var(--muted-fg)}
.template-card .btn{margin-top:1rem}

/* ==========================================================================
   6. Random selector page
   ========================================================================== */
.quick-picks{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1.5rem}
.quick-picks button{border-radius:999px;border:1px solid var(--border);background:#fff;padding:.5rem 1rem;font-size:.85rem;font-weight:500}
.quick-picks button:hover{border-color:var(--primary);color:var(--primary)}
.history-box{margin-top:3rem;padding:1.5rem}
.history-box .row-head{display:flex;align-items:center;justify-content:space-between}
.history-list{margin-top:1rem;border-top:1px solid var(--border)}
.history-list li{display:flex;align-items:center;justify-content:space-between;padding:.65rem 0;border-bottom:1px solid var(--border);font-size:.88rem}
.history-list .dot{display:inline-block;height:.75rem;width:.75rem;border-radius:999px;margin-right:.5rem}

/* ==========================================================================
   7. User guide
   ========================================================================== */
.guide-layout{display:grid;gap:2.5rem;margin-top:2.5rem;grid-template-columns:1fr}
@media(min-width:1024px){.guide-layout{grid-template-columns:220px 1fr}}
.guide-nav{position:sticky;top:6rem;display:flex;flex-direction:column;gap:.15rem}
.guide-nav a{border-radius:.6rem;padding:.5rem .75rem;font-size:.85rem;color:var(--muted-fg)}
.guide-nav a:hover{background:var(--muted-bg);color:var(--primary)}
.guide-sections{display:flex;flex-direction:column;gap:1.75rem}
.guide-section{padding:1.5rem;scroll-margin-top:6rem}
.guide-section h2{font-size:1.15rem;font-weight:700}
.guide-section > p{margin-top:.4rem;font-size:.9rem;color:var(--muted-fg)}
.guide-section ol{margin-top:1rem;padding-left:1.2rem;display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}
.kbd-table{margin-top:1rem;width:100%;font-size:.9rem;border-collapse:collapse}
.kbd-table td{padding:.5rem 0;border-bottom:1px solid var(--border)}
kbd{border:1px solid var(--border);background:var(--muted-bg);padding:.1rem .5rem;border-radius:.3rem;font-family:monospace;font-size:.8rem}
.guide-cta{border-radius:1.5rem;padding:2.5rem;text-align:center;color:#fff;background-image:var(--navy-grad)}
.guide-cta p{font-weight:700;font-size:1.2rem}

/* ==========================================================================
   8. Blog
   ========================================================================== */
.blog-grid{display:grid;gap:1.5rem;grid-template-columns:1fr;margin-top:2.5rem}
@media(min-width:640px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.blog-grid{grid-template-columns:1fr 1fr 1fr}}
.blog-card{display:flex;flex-direction:column;overflow:hidden}
.blog-card .thumb{height:10rem;width:100%;background-size:cover;background-position:center}
.blog-card .body{display:flex;flex:1;flex-direction:column;padding:1.25rem}
.blog-card .tag{width:fit-content;border-radius:999px;background:var(--accent-bg);color:var(--primary);padding:.15rem .65rem;font-size:.72rem;font-weight:700}
.blog-card h3{margin-top:.75rem;font-weight:700}
.blog-card p{margin-top:.4rem;flex:1;font-size:.88rem;color:var(--muted-fg)}
.blog-card .meta{margin-top:1rem;font-size:.75rem;color:var(--muted-fg)}
.load-more{text-align:center;margin-top:2.5rem}

.post-hero{height:14rem;width:100%;border-radius:1.1rem;background-size:cover;background-position:center;margin-top:1.5rem}
.post-content{margin-top:2rem;font-size:1rem;line-height:1.8}
.post-content p{margin-bottom:1.1rem}
.post-content h2{margin:1.75rem 0 .75rem;font-size:1.3rem;font-weight:700}
.back-link{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--primary)}
article .tag{display:inline-block;margin-top:1.5rem;border-radius:999px;background:var(--accent-bg);color:var(--primary);padding:.2rem .7rem;font-size:.75rem;font-weight:700}
.post-title{margin-top:.75rem;font-size:2rem;font-weight:800}
.post-meta{margin-top:.5rem;font-size:.85rem;color:var(--muted-fg)}
.pagination{display:flex;justify-content:center;gap:.5rem;margin-top:2.5rem}
.pagination a,.pagination span{border:1px solid var(--border);border-radius:.6rem;padding:.4rem .8rem;font-size:.85rem}
.pagination .current{background:var(--secondary);color:#fff}

/* ==========================================================================
   9. Legal pages
   ========================================================================== */
.legal-wrap{max-width:48rem;margin:0 auto;padding:3rem 1rem}
.legal-wrap h1{font-size:2.2rem;font-weight:800}
.legal-wrap .updated{margin-top:.4rem;font-size:.85rem;color:var(--muted-fg)}
.legal-wrap .entry-content{margin-top:2rem}
.legal-wrap .entry-content h2{margin-top:1.75rem;font-size:1.2rem;font-weight:700}
.legal-wrap .entry-content p{margin-top:.5rem;color:var(--muted-fg);line-height:1.75}

/* ==========================================================================
   10. Footer
   ========================================================================== */
.site-footer{margin-top:5rem;background:var(--secondary);color:#fff}
.footer-top{max-width:var(--container-wide);margin:0 auto;padding:3.5rem 1rem;display:grid;gap:2.5rem;grid-template-columns:1fr}
@media(min-width:768px){.footer-top{grid-template-columns:1.3fr 1fr 1fr 1fr;padding:3.5rem 2rem}}
.footer-brand p{margin-top:1rem;max-width:18rem;font-size:.88rem;color:rgba(255,255,255,.6)}
.footer-col h4{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.8)}
.footer-col ul{margin-top:1rem;display:flex;flex-direction:column;gap:.6rem}
.footer-col a{font-size:.88rem;color:rgba(255,255,255,.6)}
.footer-col a:hover{color:var(--primary)}
.footer-stats{max-width:var(--container-wide);margin:0 auto;padding:1.5rem 1rem;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center}
.footer-stats .num{font-family:"Poppins",sans-serif;font-size:1.5rem;font-weight:800;color:var(--primary)}
.footer-stats .lbl{font-size:.72rem;color:rgba(255,255,255,.5)}
.footer-bottom{max-width:var(--container-wide);margin:0 auto;padding:1.5rem 1rem;display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:space-between}
@media(min-width:640px){.footer-bottom{flex-direction:row}}
.socials{display:flex;gap:.6rem}
.socials a{display:flex;height:2rem;width:2rem;align-items:center;justify-content:center;border-radius:999px;background:rgba(255,255,255,.1)}
.socials a:hover{background:var(--primary)}
.legal-links{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;font-size:.75rem;color:rgba(255,255,255,.5)}
.legal-links a:hover{color:#fff}

/* ==========================================================================
   11. Utilities & motion
   ========================================================================== */
@keyframes spinFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.animate-float{animation:spinFloat 4s ease-in-out infinite}
@media (prefers-reduced-motion: reduce){
  .animate-float{animation:none}
  .wheel-svg.is-spinning{transition-duration:.4s}
  html{scroll-behavior:auto}
}
.sr-only{position:absolute;left:-9999px}
