/* ================================================
   Crystalline Sky Mist — Main Stylesheet
   Design: Japanese Minimalism × Board Game Culture
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&family=Noto+Serif+JP:wght@400;600;700&display=swap');

/* === CSS VARIABLES === */
:root {
  --bg:          #FAFAF7;
  --white:       #FFFFFF;
  --primary:     #1A2744;
  --primary-lt:  #263460;
  --accent:      #C0392B;
  --accent-hv:   #A93226;
  --gold:        #C8972B;
  --gold-lt:     #F5E6C0;
  --text:        #1A1A1A;
  --text-md:     #555555;
  --text-lt:     #888888;
  --border:      #E5E0D5;
  --section-bg:  #F2EDE6;
  --card-bg:     #FFFFFF;
  --success:     #27AE60;
  --tag-bg:      #EAF0FF;
  --tag-color:   #1A2744;
  --font-sans:   'Noto Sans JP','Hiragino Sans','Yu Gothic',Meiryo,sans-serif;
  --font-serif:  'Noto Serif JP','Hiragino Mincho Pro','Yu Mincho',serif;
  --shadow-sm:   0 1px 4px rgba(0,0,0,0.07);
  --shadow-md:   0 4px 14px rgba(0,0,0,0.10);
  --shadow-lg:   0 8px 28px rgba(0,0,0,0.13);
  --r-sm:        6px;
  --r-md:        12px;
  --r-lg:        20px;
  --transition:  all 0.25s ease;
}

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:var(--transition)}
ul{list-style:none}
button,input,select,textarea{font-family:inherit}

/* === TYPOGRAPHY === */
h1,h2,h3,h4,h5{font-family:var(--font-serif);line-height:1.35;color:var(--primary)}
h1{font-size:clamp(1.75rem,4vw,2.8rem)}
h2{font-size:clamp(1.4rem,3vw,2.1rem)}
h3{font-size:clamp(1.1rem,2vw,1.5rem)}
h4{font-size:1.1rem}
p{color:var(--text-md);line-height:1.8}

/* === LAYOUT === */
.container{max-width:1180px;margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.section-alt{background:var(--section-bg)}
.section-white{background:var(--white)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.flex{display:flex}
.flex-center{display:flex;align-items:center;justify-content:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}

/* === SECTION HEADER === */
.section-header{text-align:center;margin-bottom:48px}
.section-header .label{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);background:#FDECEA;padding:4px 14px;border-radius:99px;margin-bottom:14px}
.section-header h2{margin-bottom:12px}
.section-header p{max-width:560px;margin:0 auto;color:var(--text-md)}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:var(--r-sm);font-size:.95rem;font-weight:700;cursor:pointer;border:2px solid transparent;transition:var(--transition);text-align:center;white-space:nowrap}
.btn-primary{background:var(--accent);color:var(--white);border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-hv);border-color:var(--accent-hv);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-secondary{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-secondary:hover{background:var(--primary);color:var(--white)}
.btn-gold{background:var(--gold);color:var(--white);border-color:var(--gold)}
.btn-gold:hover{background:#b5851f;border-color:#b5851f;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--text-md);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn-white{background:var(--white);color:var(--primary);border-color:var(--white)}
.btn-white:hover{background:rgba(255,255,255,.9);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-outline-white{background:transparent;color:var(--white);border-color:rgba(255,255,255,.5)}
.btn-outline-white:hover{background:rgba(255,255,255,.1);border-color:var(--white)}
.btn-sm{padding:8px 18px;font-size:.85rem}
.btn-lg{padding:15px 34px;font-size:1.05rem}
.btn-block{width:100%;justify-content:center}

/* === HEADER === */
.site-header{position:sticky;top:0;z-index:1000;background:var(--white);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:20px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-serif);font-size:1.2rem;font-weight:700;color:var(--primary);white-space:nowrap}
.logo-icon{width:38px;height:38px;background:var(--primary);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.2rem;flex-shrink:0}
.logo-sub{font-size:.65rem;font-family:var(--font-sans);font-weight:400;color:var(--text-lt);display:block;line-height:1}
.site-nav{display:flex;align-items:center;gap:2px}
.site-nav a{padding:8px 12px;border-radius:var(--r-sm);font-size:.86rem;font-weight:500;color:var(--text-md)}
.site-nav a:hover,.site-nav a.active{background:var(--section-bg);color:var(--primary)}
.nav-dropdown{position:relative}
.nav-dropdown-menu{display:none;position:absolute;top:calc(100% + 8px);left:0;min-width:200px;background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:8px;z-index:100}
.nav-dropdown:hover .nav-dropdown-menu{display:block}
.nav-dropdown-menu a{display:block;padding:9px 14px;border-radius:var(--r-sm);font-size:.86rem}
.nav-dropdown-menu a:hover{background:var(--section-bg)}
.header-actions{display:flex;align-items:center;gap:8px}
.icon-btn{width:38px;height:38px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:var(--transition);position:relative;text-decoration:none;color:var(--text)}
.icon-btn:hover{background:var(--section-bg);border-color:var(--primary)}
.badge{position:absolute;top:-5px;right:-5px;background:var(--accent);color:white;font-size:.62rem;font-weight:700;width:17px;height:17px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.hamburger span{display:block;width:22px;height:2px;background:var(--primary);border-radius:2px;transition:var(--transition)}

/* === MOBILE NAV === */
.mobile-nav{display:none;position:fixed;top:64px;left:0;right:0;bottom:0;background:var(--white);z-index:999;overflow-y:auto;padding:20px;flex-direction:column;gap:4px}
.mobile-nav.open{display:flex}
.mobile-nav a{padding:12px 16px;border-radius:var(--r-sm);font-size:1rem;font-weight:500;color:var(--text);border-bottom:1px solid var(--border)}
.mobile-nav a:hover{background:var(--section-bg);color:var(--primary)}
.mobile-nav .sub{padding-left:30px;font-size:.9rem}

/* === BREADCRUMB === */
.breadcrumb{padding:14px 0;border-bottom:1px solid var(--border);background:var(--white)}
.breadcrumb ol{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:.82rem;color:var(--text-lt)}
.breadcrumb ol li+li::before{content:'›';margin-right:6px}
.breadcrumb a{color:var(--text-md)}
.breadcrumb a:hover{color:var(--accent)}

/* === HERO === */
.hero{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-lt) 60%,#3a4f8c 100%);color:var(--white);padding:80px 0;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E")}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:var(--white);padding:5px 14px;border-radius:99px;font-size:.78rem;font-weight:500;letter-spacing:.08em;margin-bottom:20px}
.hero h1{color:var(--white);margin-bottom:18px}
.hero p{color:rgba(255,255,255,.82);font-size:1.05rem;margin-bottom:32px;max-width:480px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-image{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3}
.hero-image img{width:100%;height:100%;object-fit:cover}

/* === STATS BAR === */
.stats-bar{background:var(--primary);color:var(--white);padding:22px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);text-align:center;gap:20px}
.stat-item .num{font-family:var(--font-serif);font-size:1.8rem;font-weight:700;color:var(--gold);display:block}
.stat-item .lbl{font-size:.82rem;color:rgba(255,255,255,.7)}

/* === GAME CARD === */
.game-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:var(--transition);display:flex;flex-direction:column}
.game-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.game-card-image{aspect-ratio:4/3;overflow:hidden;position:relative}
.game-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.game-card:hover .game-card-image img{transform:scale(1.04)}
.game-card-badge{position:absolute;top:10px;left:10px;background:var(--accent);color:white;font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:99px}
.game-card-body{padding:16px;flex:1;display:flex;flex-direction:column}
.game-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.tag{font-size:.72rem;font-weight:500;background:var(--tag-bg);color:var(--tag-color);padding:2px 9px;border-radius:99px}
.tag-green{background:#E6F7EE;color:#1E7E45}
.tag-gold{background:var(--gold-lt);color:#7A5A10}
.tag-red{background:#FDECEA;color:var(--accent)}
.game-card-title{font-size:1rem;font-weight:700;margin-bottom:6px;color:var(--primary);font-family:var(--font-sans)}
.game-card-meta{font-size:.8rem;color:var(--text-lt);margin-bottom:10px;display:flex;flex-wrap:wrap;gap:10px}
.game-card-meta span{display:flex;align-items:center;gap:4px}
.stars{color:var(--gold);font-size:.85rem;display:flex;align-items:center;gap:2px}
.stars-count{font-size:.78rem;color:var(--text-lt)}
.game-card-price{font-size:1.05rem;font-weight:700;color:var(--accent);margin-top:auto;padding-top:10px}
.game-card-price .original{text-decoration:line-through;font-size:.82rem;color:var(--text-lt);font-weight:400;margin-right:6px}
.game-card-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:8px}

/* === CATEGORY CARD === */
.cat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-md);padding:28px 20px;text-align:center;transition:var(--transition);cursor:pointer;display:block}
.cat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--primary)}
.cat-icon{font-size:2.4rem;margin-bottom:12px}
.cat-card h3{font-size:1rem;font-family:var(--font-sans);font-weight:700;margin-bottom:6px}
.cat-card p{font-size:.82rem;color:var(--text-lt);margin-bottom:10px}
.cat-count{font-size:.78rem;font-weight:700;color:var(--accent);background:#FDECEA;padding:2px 10px;border-radius:99px;display:inline-block}

/* === BLOG CARD === */
.blog-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:var(--transition)}
.blog-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.blog-card-image{aspect-ratio:16/9;overflow:hidden}
.blog-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.blog-card:hover .blog-card-image img{transform:scale(1.04)}
.blog-card-body{padding:18px}
.blog-card-meta{font-size:.78rem;color:var(--text-lt);margin-bottom:10px;display:flex;gap:12px;flex-wrap:wrap}
.blog-card-title{font-size:.98rem;font-weight:700;color:var(--primary);font-family:var(--font-sans);margin-bottom:8px;line-height:1.5}
.blog-card-excerpt{font-size:.85rem;color:var(--text-md);line-height:1.7}

/* === REVIEW CARD === */
.review-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-md);padding:22px}
.review-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.reviewer-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-lt));display:flex;align-items:center;justify-content:center;color:white;font-weight:700;font-size:1.1rem;flex-shrink:0}
.reviewer-name{font-weight:700;font-size:.92rem}
.reviewer-date{font-size:.78rem;color:var(--text-lt)}
.review-game{font-size:.82rem;color:var(--text-md);margin-bottom:8px}
.review-text{font-size:.88rem;color:var(--text-md);line-height:1.75}
.review-helpful{font-size:.78rem;color:var(--text-lt);margin-top:12px}

/* === FORUM === */
.forum-topic{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-md);padding:18px 20px;display:flex;gap:16px;align-items:flex-start;transition:var(--transition)}
.forum-topic:hover{box-shadow:var(--shadow-sm);border-color:var(--primary)}
.forum-icon{font-size:1.6rem;flex-shrink:0;margin-top:2px}
.forum-topic-meta{font-size:.78rem;color:var(--text-lt);margin-top:5px;display:flex;gap:12px;flex-wrap:wrap}
.forum-counts{margin-left:auto;text-align:right;flex-shrink:0}
.forum-counts .count{font-size:1.2rem;font-weight:700;color:var(--primary);display:block}
.forum-counts .lbl{font-size:.72rem;color:var(--text-lt)}

/* === FILTERS === */
.filter-bar{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);padding:20px 24px;margin-bottom:28px}
.filter-bar h3{font-size:.95rem;font-family:var(--font-sans);font-weight:700;margin-bottom:16px;color:var(--primary)}
.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.filter-group label{display:block;font-size:.78rem;font-weight:600;color:var(--text-md);margin-bottom:5px}
.filter-group select,.filter-group input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:.85rem;background:var(--bg);color:var(--text);cursor:pointer;transition:var(--transition)}
.filter-group select:focus,.filter-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,39,68,.08)}
.filter-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}

/* === SEARCH BOX === */
.search-form{display:flex;border:2px solid var(--primary);border-radius:var(--r-sm);overflow:hidden;background:var(--white)}
.search-form input{flex:1;padding:13px 18px;border:none;font-size:.95rem;background:transparent;color:var(--text)}
.search-form input:focus{outline:none}
.search-form button{padding:13px 22px;background:var(--primary);color:var(--white);border:none;cursor:pointer;font-size:.95rem;font-weight:700;transition:var(--transition);font-family:var(--font-sans)}
.search-form button:hover{background:var(--primary-lt)}

/* === FORMS === */
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:.88rem;font-weight:600;margin-bottom:6px;color:var(--text)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 15px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:.92rem;background:var(--white);color:var(--text);transition:var(--transition);line-height:1.6}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,39,68,.08)}
.form-group textarea{resize:vertical;min-height:120px}
.form-hint{font-size:.78rem;color:var(--text-lt);margin-top:4px}

/* === PAGINATION === */
.pagination{display:flex;gap:6px;justify-content:center;margin-top:48px;flex-wrap:wrap}
.page-btn{width:38px;height:38px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:center;font-size:.88rem;cursor:pointer;transition:var(--transition);text-decoration:none;color:var(--text)}
.page-btn:hover,.page-btn.active{background:var(--primary);color:var(--white);border-color:var(--primary)}

/* === TABS === */
.tabs{display:flex;gap:2px;border-bottom:2px solid var(--border);margin-bottom:28px;overflow-x:auto}
.tab-btn{padding:10px 20px;border:none;background:none;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--text-md);border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:var(--transition);font-family:var(--font-sans)}
.tab-btn:hover{color:var(--primary)}
.tab-btn.active{color:var(--primary);border-bottom-color:var(--accent);font-weight:700}

/* === ACCORDION === */
.accordion-item{border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:10px;overflow:hidden}
.accordion-header{width:100%;padding:18px 22px;background:var(--white);border:none;text-align:left;font-size:.95rem;font-weight:600;color:var(--primary);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--font-sans);transition:var(--transition)}
.accordion-header:hover{background:var(--section-bg)}
.accordion-icon{font-size:1.2rem;flex-shrink:0;transition:transform .25s;line-height:1}
.accordion-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.accordion-body-inner{padding:0 22px 18px;font-size:.9rem;color:var(--text-md);line-height:1.8}
.accordion-item.open .accordion-body{max-height:500px}
.accordion-item.open .accordion-icon{transform:rotate(45deg)}

/* === CART === */
.cart-item{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.cart-item-img{width:80px;height:80px;border-radius:var(--r-sm);overflow:hidden;flex-shrink:0}
.cart-item-img img{width:100%;height:100%;object-fit:cover}
.cart-item-info{flex:1}
.cart-item-name{font-weight:700;margin-bottom:4px;font-size:.95rem;color:var(--primary)}
.cart-item-meta{font-size:.8rem;color:var(--text-lt)}
.qty-control{display:flex;align-items:center;gap:10px;margin-top:10px}
.qty-btn{width:28px;height:28px;border-radius:4px;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;font-family:var(--font-sans);line-height:1}
.qty-btn:hover{border-color:var(--primary);background:var(--section-bg)}
.qty-input{width:42px;text-align:center;border:1px solid var(--border);border-radius:4px;padding:4px;font-size:.9rem}
.cart-item-price{font-weight:700;font-size:1rem;color:var(--accent);text-align:right;white-space:nowrap}

/* === ORDER SUMMARY === */
.order-summary{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);padding:24px;position:sticky;top:80px}
.order-summary h3{font-size:1.05rem;font-family:var(--font-sans);font-weight:700;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.summary-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-md);margin-bottom:10px}
.summary-row.total{font-size:1.1rem;font-weight:700;color:var(--text);padding-top:12px;border-top:1px solid var(--border);margin-top:4px}
.summary-row.total span:last-child{color:var(--accent)}

/* === NOTICE === */
.notice{padding:14px 18px;border-radius:var(--r-sm);font-size:.88rem;border-left:4px solid;margin-bottom:20px}
.notice-info{background:#EBF4FF;border-color:#3498DB;color:#1a5276}
.notice-success{background:#E6F7EE;border-color:var(--success);color:#145A32}
.notice-warning{background:#FEF9E7;border-color:#F39C12;color:#7E5109}

/* === RATINGS === */
.rating-bar-row{display:flex;align-items:center;gap:10px;font-size:.82rem;margin-bottom:6px}
.rating-bar-track{flex:1;height:6px;background:var(--border);border-radius:99px;overflow:hidden}
.rating-bar-fill{height:100%;background:var(--gold);border-radius:99px}
.rating-big{text-align:center}
.rating-big .num{font-size:3.5rem;font-weight:900;font-family:var(--font-serif);color:var(--primary);line-height:1}
.rating-big .total{font-size:.82rem;color:var(--text-lt);margin-top:6px}

/* === FOOTER === */
.site-footer{background:var(--primary);color:rgba(255,255,255,.8);padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-brand .logo{color:var(--white);margin-bottom:14px}
.footer-brand p{font-size:.85rem;line-height:1.8;max-width:280px}
.footer-col h4{font-family:var(--font-sans);font-size:.88rem;font-weight:700;color:var(--white);margin-bottom:16px;letter-spacing:.05em}
.footer-col ul{display:flex;flex-direction:column;gap:9px}
.footer-col ul li a{font-size:.84rem;color:rgba(255,255,255,.65)}
.footer-col ul li a:hover{color:var(--gold)}
.footer-contact{font-size:.84rem;margin-top:14px}
.footer-contact p{margin-bottom:6px;color:rgba(255,255,255,.65)}
.footer-contact a{color:var(--gold)}
.footer-social{display:flex;gap:10px;margin-top:18px}
.social-btn{width:36px;height:36px;border-radius:var(--r-sm);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:var(--transition);color:rgba(255,255,255,.8);text-decoration:none}
.social-btn:hover{background:var(--gold);border-color:var(--gold);color:var(--primary)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:.8rem;color:rgba(255,255,255,.45)}
.footer-bottom a{color:rgba(255,255,255,.6)}
.footer-bottom a:hover{color:var(--gold)}
.footer-bottom-links{display:flex;gap:18px}

/* === BACK TO TOP === */
.back-to-top{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--primary);color:var(--white);border:none;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:var(--transition);z-index:100;opacity:0;pointer-events:none}
.back-to-top.visible{opacity:1;pointer-events:auto}
.back-to-top:hover{background:var(--accent);transform:translateY(-2px)}

/* === SIDEBAR === */
.sidebar-widget{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);padding:20px;margin-bottom:20px}
.sidebar-widget h4{font-size:.95rem;font-family:var(--font-sans);font-weight:700;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.sidebar-tags{display:flex;flex-wrap:wrap;gap:6px}
.sidebar-list li{padding:8px 0;border-bottom:1px solid var(--border);font-size:.88rem;display:flex;justify-content:space-between;align-items:center}
.sidebar-list li:last-child{border-bottom:none}
.sidebar-list a{color:var(--text-md)}
.sidebar-list a:hover{color:var(--accent)}

/* === UTILITIES === */
.text-center{text-align:center}
.text-right{text-align:right}
.text-accent{color:var(--accent)}
.text-gold{color:var(--gold)}
.text-primary{color:var(--primary)}
.text-light{color:var(--text-lt)}
.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}
.divider{border:none;border-top:1px solid var(--border);margin:28px 0}
.highlight{background:var(--gold-lt);padding:2px 6px;border-radius:3px}
.img-rounded{border-radius:var(--r-md);overflow:hidden}
.img-cover{width:100%;height:100%;object-fit:cover}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .grid-4{grid-template-columns:repeat(3,1fr)}
  .hero-inner{gap:40px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .site-nav{display:none}
  .hamburger{display:flex}
  .hero-inner{grid-template-columns:1fr;gap:30px}
  .hero-image{display:none}
  .hero{padding:52px 0}
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .section{padding:52px 0}
  .filter-grid{grid-template-columns:repeat(2,1fr)}
  .header-actions .btn{display:none}
}
@media(max-width:480px){
  .grid-3,.grid-4{grid-template-columns:1fr}
  .hero h1{font-size:1.6rem}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .filter-grid{grid-template-columns:1fr}
  .footer-bottom-links{flex-wrap:wrap;gap:10px;justify-content:center}
}
