﻿:root {
  --primary: #c5161d;
  --primary-dark: #c5161d;
  --primary-deeper: #c5161d;
  --primary-light: #fff1f0;
  --red-accent: #c5161d;
  --white: #fff;
  --bg-gray: #f3f6fa;
  --bg-light: #f8fafc;
  --text-black: #1f2937;
  --text-dark: #4b5563;
  --text-gray: #6b7280;
  --text-light: #9ca3af;
  --border: #d8dee8;
  --border-light: #e6ebf2;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,'PingFang SC','Microsoft YaHei','Helvetica Neue',sans-serif;color:var(--text-black);font-size:14px;line-height:1.8;background:var(--bg-gray)}
a{text-decoration:none;color:var(--text-black)}
a:hover{color:var(--primary)}
img{max-width:100%;display:block}
ul,ol{list-style:none}
.clearfix::after{content:'';display:table;clear:both}

/* === WRAPPER === */
.w{max-width:1200px;margin:0 auto;padding:0 10px}

/* === TOP BAR === */
.topbar{background:var(--primary);border-bottom:none;font-size:12px;color:rgba(255,255,255,.72);padding:6px 0}
.topbar .w{display:flex;justify-content:space-between;align-items:center}
.topbar a{color:rgba(255,255,255,.72);margin-left:12px;font-size:12px}
.topbar a:hover{color:#fff}

/* === HEADER === */
.header{background:var(--white);padding:16px 0;border-bottom:1px solid var(--border)}
.header .w{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:14px}
.logo-img{width:52px;height:52px;object-fit:contain;flex-shrink:0;border-radius:6px}
.logo-info h1{font-size:26px;font-weight:900;color:var(--primary-dark);letter-spacing:3px;line-height:1.3}
.logo-info p{font-size:12px;color:var(--text-gray);letter-spacing:1px}
.header-right{display:flex;align-items:center;gap:16px}
.search-box{display:flex;border:1px solid var(--border);overflow:hidden}
.search-box input{border:none;padding:6px 12px;font-size:13px;width:200px;outline:none;font-family:inherit}
.search-box button{border:none;background:var(--primary);color:#fff;padding:6px 14px;cursor:pointer;font-size:13px;font-family:inherit}
.search-box button:hover{background:var(--primary-dark)}

/* === NAV === */
.navbar{background:var(--primary)}
.navbar .w{display:flex;align-items:center}
.nav-menu{display:flex;flex:1}
.navbar a{display:block;padding:12px 0;color:#fff;font-size:15px;font-weight:500;text-align:center;flex:1;transition:background .2s}
.navbar a:hover,.navbar a.on{background:rgba(0,0,0,.22);color:#fff}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:10px;flex-direction:column;gap:4px}
.nav-toggle span{width:20px;height:2px;background:#fff}

/* === BANNER SLIDER === */
.banner{position:relative;overflow:hidden;background:var(--primary-deeper)}
.slides{display:flex;transition:transform .5s ease;width:300%}
.slide{width:33.333%;position:relative}
.slide-img{min-height:400px;background:var(--primary);display:flex;flex-direction:column;align-items:center;justify-content:center;color:rgba(255,255,255,.4);gap:8px;font-size:13px;overflow:hidden}
.slide-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.slide-caption{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.55);color:#fff;padding:14px 24px;font-size:15px}
.slide-dots{position:absolute;bottom:20px;right:24px;display:flex;gap:8px;z-index:5}
.slide-dots span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer}
.slide-dots span.active{background:#fff}
.slide-arrows{position:absolute;top:50%;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;padding:0 10px;z-index:5}
.slide-arrows button{background:rgba(0,0,0,.3);border:none;color:#fff;width:36px;height:36px;cursor:pointer;font-size:18px}
.slide-arrows button:hover{background:rgba(0,0,0,.5)}

/* === BREADCRUMB === */
.breadcrumb{background:var(--white);border-bottom:1px solid var(--border-light);padding:8px 0;font-size:12px;color:var(--text-gray)}
.breadcrumb .w{display:flex;align-items:center;gap:6px}
.breadcrumb a{color:var(--text-gray)}
.breadcrumb a:hover{color:var(--primary)}
.breadcrumb span{color:var(--text-light)}

/* === PAGE HERO (subpages) === */
.page-hero{background:var(--primary);padding:24px 0;color:#fff}
.page-hero h2{font-size:22px;font-weight:700;letter-spacing:2px}
.page-hero p{font-size:13px;color:rgba(255,255,255,.7);margin-top:4px}

/* === SECTION MODULE === */
.section{padding:30px 0}
.module{background:var(--white);margin-bottom:20px;padding:20px 24px;border:1px solid var(--border-light);border-radius:6px}

/* section title bar */
.mod-title{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--primary);padding-bottom:10px;margin-bottom:18px}
.mod-title h2{font-size:18px;font-weight:700;color:var(--text-black);display:flex;align-items:center;gap:8px}
.mod-title h2 .bar{width:4px;height:18px;background:var(--primary);display:inline-block;border-radius:1px}
.mod-title .more{font-size:12px;color:var(--text-gray)}
.mod-title .more:hover{color:var(--primary)}

/* === MAIN + SIDEBAR LAYOUT === */
.layout{display:flex;gap:20px}
.layout .main{flex:1;min-width:0}
.layout .side{width:300px;flex-shrink:0}

/* === NEWS LIST === */
.news-list{list-style:none}
.news-list li{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--border-light)}
.news-list li:last-child{border-bottom:none}
.news-list .thumb{width:140px;height:90px;flex-shrink:0;overflow:hidden;background:var(--bg-gray);display:flex;align-items:center;justify-content:center}
.news-list .thumb img{width:100%;height:100%;object-fit:cover}
.news-list .thumb .no-img{width:100%;height:90px;background:var(--bg-gray);display:flex;align-items:center;justify-content:center;color:var(--text-light);font-size:11px}
.news-list .info h4{font-size:15px;font-weight:500;margin-bottom:4px;line-height:1.5}
.news-list .info h4 a:hover{color:var(--primary)}
.news-list .info p{font-size:12px;color:var(--text-gray);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news-list .info .date{font-size:11px;color:var(--text-light);margin-top:4px}

/* simple text list */
.text-list li{padding:8px 0;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center;font-size:14px}
.text-list li:last-child{border-bottom:none}
.text-list li a{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:10px}
.text-list li a::before{content:'•';color:var(--primary);font-weight:700;margin-right:6px}
.text-list li .date{font-size:12px;color:var(--text-light);flex-shrink:0}

/* === ICON GRID (services) - Enhanced === */
.icon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.icon-item{text-align:center;padding:28px 16px;background:var(--bg-light);border:1px solid var(--border-light);border-radius:6px;transition:all .22s ease;cursor:pointer;position:relative;overflow:hidden}
.icon-item::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--primary-light),transparent);opacity:0;transition:opacity .3s ease}
.icon-item:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 8px 20px rgba(197,22,29,.12)}
.icon-item:hover::before{opacity:1}
.icon-item .ic{width:56px;height:56px;margin:0 auto 12px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:700;position:relative;z-index:1;transition:transform .3s ease,box-shadow .3s ease}
.icon-item:hover .ic{transform:scale(1.04);box-shadow:0 6px 14px rgba(197,22,29,.24)}
.icon-item h4{font-size:15px;margin-bottom:4px;position:relative;z-index:1;font-weight:600}
.icon-item p{font-size:12px;color:var(--text-gray);position:relative;z-index:1}

/* === CARD GRID - Enhanced === */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{border:1px solid var(--border-light);background:var(--white);overflow:hidden;transition:all .22s ease;border-radius:6px;position:relative}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(197,22,29,.1)}
.card .card-img{height:180px;overflow:hidden;background:var(--bg-gray);display:flex;align-items:center;justify-content:center;position:relative}
.card .card-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.card:hover .card-img img{transform:scale(1.08)}
.card .card-body{padding:18px 20px}
.card .card-body h4{font-size:16px;font-weight:600;margin-bottom:8px;line-height:1.5;color:var(--text-black);transition:color .2s ease}
.card:hover .card-body h4{color:var(--primary)}
.card .card-body p{font-size:13px;color:var(--text-gray);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* === TWO COLUMN CONTENT - Enhanced === */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-bottom:24px}
.col-box{background:var(--white);border:1px solid var(--border-light);padding:24px;border-radius:6px;transition:box-shadow .22s ease;position:relative}
.col-box::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:12px 12px 0 0;opacity:0;transition:opacity .3s ease}
.col-box:hover{box-shadow:0 8px 20px rgba(197,22,29,.08)}
.col-box:hover::before{opacity:1}
.col-box .mod-title{margin-bottom:16px}

/* === DATA DISPLAY - Enhanced === */
.data-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:var(--primary);overflow:hidden;border-radius:6px;box-shadow:0 8px 24px rgba(197,22,29,.18)}
.data-item{text-align:center;padding:36px 20px;border-right:1px solid rgba(255,255,255,.12);position:relative;overflow:hidden}
.data-item::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,rgba(255,255,255,.1) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}
.data-item:hover::before{opacity:1}
.data-item:last-child{border-right:none}
.data-item .num{font-size:36px;font-weight:900;color:#fff;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.1)}
.data-item .unit{font-size:13px;color:rgba(255,255,255,.7);margin:6px 0 10px;font-weight:500}
.data-item .label{font-size:14px;color:rgba(255,255,255,.9);font-weight:500}

/* === TABLE === */
.data-table{width:100%;border-collapse:collapse}
.data-table th{background:var(--primary);color:#fff;padding:10px 14px;font-size:13px;font-weight:500;text-align:left}
.data-table td{padding:9px 14px;font-size:13px;border-bottom:1px solid var(--border-light)}
.data-table tr:hover td{background:var(--primary-light)}

/* === PARTNER LOGOS === */
.partner-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.partner-tag{padding:8px 18px;border:1px solid var(--border);font-size:13px;color:var(--text-dark);background:var(--bg-light)}
.partner-tag:hover{border-color:var(--primary);color:var(--primary)}

/* === LINKS SECTION === */
.links-section{background:var(--white);padding:20px 24px;margin-bottom:20px;border:1px solid var(--border-light)}
.links-section h3{font-size:14px;font-weight:700;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:6px}
.links-section h3 .bar{width:3px;height:14px;background:var(--primary);display:inline-block}
.links-wrap{display:flex;flex-wrap:wrap;gap:6px 16px}
.links-wrap a{font-size:13px;color:var(--text-dark)}
.links-wrap a:hover{color:var(--primary)}

/* === FAQ === */
.faq-item{border:1px solid var(--border-light);margin-bottom:6px}
.faq-q{padding:12px 16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:500}
.faq-q:hover{background:var(--primary-light)}
.faq-q .arr{color:var(--primary);transition:transform .2s;font-size:12px}
.faq-item.open .faq-q{background:var(--primary-light);color:var(--primary-dark)}
.faq-item.open .arr{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s;padding:0 16px}
.faq-item.open .faq-a{max-height:200px;padding:0 16px 12px}
.faq-a p{font-size:13px;color:var(--text-dark);line-height:1.8}

/* === PAGINATION === */
.pagination{display:flex;justify-content:center;gap:6px;padding:20px 0}
.pagination a,.pagination span{display:inline-block;padding:6px 12px;border:1px solid var(--border);font-size:13px;color:var(--text-dark);background:var(--white)}
.pagination a:hover{border-color:var(--primary);color:var(--primary)}
.pagination .active{background:var(--primary);color:#fff;border-color:var(--primary)}
.pagination .disabled{color:var(--text-light);cursor:default}

/* === NEWS DETAIL === */
.article-header{padding:24px 24px 16px;background:var(--white);border:1px solid var(--border-light);margin-bottom:16px}
.article-header h1{font-size:22px;font-weight:700;line-height:1.5;margin-bottom:12px}
.article-meta{font-size:12px;color:var(--text-gray);display:flex;gap:16px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}
.article-cover{width:100%;max-height:400px;object-fit:cover;margin-bottom:20px}
.article-body{background:var(--white);border:1px solid var(--border-light);padding:24px;margin-bottom:16px;line-height:1.9;font-size:15px;color:var(--text-dark)}
.article-body p{margin-bottom:14px}
.article-body h2,.article-body h3{font-size:17px;font-weight:700;margin:20px 0 10px;color:var(--text-black)}
.article-body img{max-width:100%;margin:16px auto}

/* === NOTICE BADGE === */
.badge{display:inline-block;padding:2px 8px;font-size:11px;font-weight:500;margin-right:6px}
.badge-notice{background:var(--primary-light);color:var(--primary);border:1px solid #f4c3c5}
.badge-pinned{background:var(--primary-light);color:var(--primary);border:1px solid #f4c3c5}

/* === FOOTER === */
.footer{background:var(--primary);color:rgba(255,255,255,.58);padding:30px 0 16px;font-size:12px;text-align:center}
.footer-brand{font-size:18px;font-weight:700;color:#fff;margin-bottom:4px;letter-spacing:2px}
.footer-links{margin:12px 0;display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.footer-links a{color:rgba(255,255,255,.5);font-size:12px}
.footer-links a:hover{color:#fff}
.footer .copy{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}

/* === MODULE DIAGRAM === */
.module-diagram{position:relative;width:100%;max-width:980px;margin:0 auto;padding:4px 0 2px;min-height:0}
.module-diagram .md-lines{display:none!important}
.md-center{position:relative;top:auto;left:auto;transform:none;z-index:3;text-align:center;display:flex;justify-content:center;margin-bottom:20px}
.md-center-inner{display:flex;align-items:center;gap:12px;background:var(--primary);color:#fff;padding:14px 24px;border-radius:8px;box-shadow:0 4px 20px rgba(210,40,46,.18)}
.md-center-icon{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:900;flex-shrink:0}
.md-center-title{font-size:18px;font-weight:700;letter-spacing:2px;line-height:1.3}
.md-center-sub{font-size:11px;opacity:.8;white-space:nowrap}

.md-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:1px dashed rgba(210,40,46,.12);pointer-events:none;z-index:1}
.md-ring-1{width:260px;height:260px;border-color:rgba(210,40,46,.18)}
.md-ring-2{width:380px;height:380px;border-color:rgba(210,40,46,.1)}

.md-nodes{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.md-node{position:static!important;top:auto!important;left:auto!important;transform:none!important;display:flex!important;flex-direction:column!important;align-items:flex-start!important;text-align:left!important;text-decoration:none;color:inherit;transition:all .2s;width:auto!important;min-height:112px;margin:0!important;padding:16px 16px 14px;background:var(--bg-light);border:1px solid var(--border-light);border-left:4px solid var(--color,var(--primary));border-radius:8px}
.md-node:hover{transform:translateY(-2px)!important;z-index:10;border-color:var(--color,var(--primary));background:#fff;box-shadow:0 8px 22px rgba(0,0,0,.08)}
.md-node:hover .md-node-dot{box-shadow:0 0 0 8px rgba(210,40,46,.12)}
.md-node-dot{width:12px;height:12px;border-radius:50%;background:var(--color,var(--primary));margin-bottom:10px;transition:box-shadow .2s}
.md-node-label{font-size:15px;font-weight:600;color:var(--text-black);white-space:normal;line-height:1.45}
.md-node-desc{font-size:12px;color:var(--text-gray);white-space:normal;margin-top:4px;line-height:1.55}

.store-map-layout{display:grid;grid-template-columns:minmax(0,7fr) minmax(260px,3fr);gap:16px;align-items:stretch}
.store-map{width:100%;height:420px;border-radius:4px;overflow:hidden;background:var(--bg-light)}
.store-list{display:flex;flex-direction:column;gap:10px;max-height:420px;overflow:auto;padding-right:4px}
.store-card{width:100%;border:1px solid var(--border-light);border-left:4px solid transparent;background:var(--bg-light);border-radius:6px;padding:12px 14px;text-align:left;cursor:pointer;font-family:inherit;line-height:1.6;transition:all .2s}
.store-card strong{display:block;font-size:14px;color:var(--text-black);font-weight:700;margin-bottom:3px}
.store-card span{display:block;font-size:12px;color:var(--text-gray)}
.store-card:hover,.store-card.active{background:var(--primary-light);border-color:#f4c3c5;border-left-color:var(--primary)}

@media(max-width:768px){
  .module-diagram{min-height:auto;padding:20px 0}
  .md-center{position:relative;top:auto;left:auto;transform:none;margin-bottom:24px;display:flex;justify-content:center}
  .md-ring{display:none}
  .md-nodes{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
  .md-node{position:static;width:auto;margin:0;flex-direction:row;gap:10px;padding:10px 14px;background:var(--bg-light);border-radius:6px;border-left:3px solid var(--color,var(--primary));text-align:left}
  .md-node-dot{width:10px;height:10px;min-width:10px;margin:0}
  .md-node-desc{white-space:normal}
  .store-map-layout{grid-template-columns:1fr}
  .store-list{max-height:none;display:grid;grid-template-columns:1fr;gap:8px;padding-right:0}
}

/* === CTA === */
.cta-btn{display:inline-block;padding:8px 24px;background:var(--primary);color:#fff;font-size:14px;border:none;cursor:pointer}
.cta-btn:hover{background:var(--primary-dark);color:#fff}

/* === ANIM === */
.anim{opacity:0;transform:translateY(12px);transition:opacity .4s,transform .4s}
.anim.show{opacity:1;transform:translateY(0)}

/* === FLOATING SIDEBAR BAR === */
.float-bar{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:150}
.float-tab{position:absolute;right:0;top:0;width:24px;height:48px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px 0 0 4px;font-size:14px;opacity:.65;transition:opacity .2s}
.float-tab:hover{opacity:1}
.float-tab.hidden{opacity:0;pointer-events:none}
.float-body{position:absolute;right:0;top:0;display:flex;flex-direction:column;gap:2px;transition:transform .3s ease,opacity .25s}
.float-body.collapsed{transform:translateX(100%);opacity:0;pointer-events:none}
.float-item{position:relative;width:56px;background:var(--primary);cursor:pointer;text-align:center;padding:10px 0;transition:background .2s}
.float-item:first-child{border-radius:4px 0 0 0}
.float-item:hover{background:var(--primary-dark)}
.float-icon{color:#fff;font-size:18px;line-height:1}
.float-label{color:rgba(255,255,255,.85);font-size:11px;margin-top:3px}
.float-close{background:var(--primary);border-radius:0 0 0 4px}
.float-close:hover{background:var(--primary)}

/* Popup card */
.float-popup{position:absolute;right:64px;top:50%;transform:translateY(-50%) translateX(10px);background:#fff;border:1px solid var(--border);box-shadow:0 4px 20px rgba(0,0,0,.12);padding:22px 24px;width:360px;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:160;border-radius:4px}
.float-item:hover .float-popup{opacity:1;pointer-events:auto;transform:translateY(-50%) translateX(0)}
.float-popup h4{font-size:14px;font-weight:600;color:var(--text-black);margin-bottom:6px}
.float-popup p{font-size:12px;color:var(--text-gray);line-height:1.8;margin:0}
.float-popup img{width:100%;margin-top:10px;border:1px solid var(--border-light)}
.popup-arrow{position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:8px solid #fff;border-top:8px solid transparent;border-bottom:8px solid transparent}

/* === BACK TO TOP (independent) === */
.back-top{position:fixed;right:20px;bottom:40px;z-index:150;width:40px;height:40px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;box-shadow:0 2px 8px rgba(0,0,0,.15);opacity:0;pointer-events:none;transition:opacity .3s,background .2s}
.back-top.show{opacity:.75;pointer-events:auto}
.back-top:hover{opacity:1;background:var(--primary-dark)}


/* 鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺?   ADMIN PANEL STYLES
鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺愨晲鈺?*/
.admin-body{background:#f0f2f5;font-family:'Noto Sans SC','Microsoft YaHei',sans-serif;color:#333}

/* Admin layout */
.admin-wrap{display:flex;min-height:100vh}
.admin-sidebar{width:220px;background:var(--primary);flex-shrink:0;position:fixed;top:0;left:0;height:100vh;overflow-y:auto;z-index:100}
.admin-sidebar .sidebar-logo{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.1)}
.admin-sidebar .sidebar-logo h2{color:#fff;font-size:16px;font-weight:700;letter-spacing:1px}
.admin-sidebar .sidebar-logo p{color:rgba(255,255,255,.4);font-size:11px}
.admin-nav{padding:10px 0}
.admin-nav a{display:flex;align-items:center;gap:10px;padding:11px 20px;color:rgba(255,255,255,.65);font-size:13px;transition:all .2s}
.admin-nav a:hover,.admin-nav a.on{background:var(--primary);color:#fff}
.admin-nav .nav-group{padding:16px 20px 6px;font-size:11px;color:rgba(255,255,255,.3);letter-spacing:1px;text-transform:uppercase}
.admin-main{margin-left:220px;flex:1}

/* Admin topbar */
.admin-topbar{background:#fff;border-bottom:1px solid #e8e8e8;padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.admin-topbar h2{font-size:16px;font-weight:600;color:#333}
.admin-topbar .top-right a{font-size:13px;color:var(--text-gray)}
.admin-topbar .top-right a:hover{color:var(--primary)}

/* Admin content area */
.admin-content{padding:24px}

/* Stats cards */
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{background:#fff;border:1px solid #e8e8e8;padding:20px 24px}
.stat-card .s-num{font-size:32px;font-weight:700;color:var(--primary);line-height:1}
.stat-card .s-label{font-size:13px;color:var(--text-gray);margin-top:6px}

/* Admin table */
.admin-table-wrap{background:#fff;border:1px solid #e8e8e8}
.admin-table-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e8e8e8}
.admin-table-header h3{font-size:15px;font-weight:600}
.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table th{background:#fafafa;padding:10px 16px;text-align:left;font-weight:500;color:#555;border-bottom:1px solid #e8e8e8}
.admin-table td{padding:10px 16px;border-bottom:1px solid #f0f0f0;vertical-align:middle}
.admin-table tr:hover td{background:#fafafa}
.admin-table .actions{display:flex;gap:8px}
.admin-table .actions a{font-size:12px;padding:3px 10px;border:1px solid;cursor:pointer}
.btn-edit{color:var(--primary);border-color:var(--primary)!important}
.btn-edit:hover{background:var(--primary);color:#fff}
.btn-del{color:var(--primary);border-color:var(--primary)!important}
.btn-del:hover{background:var(--primary);color:#fff}
.btn-view{color:#666;border-color:#ccc!important}
.btn-view:hover{background:#666;color:#fff}

/* Form styles */
.admin-form-wrap{background:#fff;border:1px solid #e8e8e8;padding:24px;max-width:900px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:13px;font-weight:500;color:#555;margin-bottom:6px}
.form-group input[type=text],
.form-group input[type=url],
.form-group input[type=number],
.form-group input[type=password],
.form-group select,
.form-group textarea{width:100%;padding:8px 12px;border:1px solid #d9d9d9;font-size:13px;font-family:inherit;outline:none;transition:border-color .2s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary)}
.form-group textarea{resize:vertical;min-height:100px}
.form-group .hint{font-size:11px;color:var(--text-gray);margin-top:4px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-check{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}
.form-check input{width:16px;height:16px;accent-color:var(--primary)}
.form-actions{display:flex;gap:12px;padding-top:16px;border-top:1px solid #f0f0f0;margin-top:20px}
.btn-primary{background:var(--primary);color:#fff;border:none;padding:9px 24px;font-size:14px;font-family:inherit;cursor:pointer}
.btn-primary:hover{background:var(--primary-dark)}
.btn-default{background:#fff;color:#555;border:1px solid #d9d9d9;padding:9px 24px;font-size:14px;font-family:inherit;cursor:pointer}
.btn-default:hover{border-color:var(--primary);color:var(--primary)}
.btn-danger{background:var(--primary);color:#fff;border:none;padding:9px 24px;font-size:14px;font-family:inherit;cursor:pointer}

/* Alert */
.alert{padding:10px 16px;margin-bottom:16px;font-size:13px;border-left:4px solid}
.alert-success{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}
.alert-error{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}

/* Quill editor */
#editor-container{border:1px solid #d9d9d9;min-height:320px;font-size:14px;font-family:'Noto Sans SC','Microsoft YaHei',sans-serif}
.ql-toolbar{border:1px solid #d9d9d9;border-bottom:none}
.ql-container{border:1px solid #d9d9d9;border-top:none;min-height:280px}

/* Image preview */
.img-preview{margin-top:8px;max-width:300px;max-height:180px;object-fit:cover;border:1px solid var(--border);display:none}
.img-preview.show{display:block}

/* Image Container - Enhanced */
.img-container{margin-bottom:14px;border-radius:6px;overflow:hidden;background:var(--bg-gray);min-height:160px;display:flex;align-items:center;justify-content:center;position:relative;border:1px solid var(--border-light)}
.img-container:hover{border-color:var(--border)}
.img-container img{width:100%;height:100%;object-fit:cover;border-radius:6px}
.img-container:hover img{transform:none}
.img-fallback{min-height:160px;background:linear-gradient(135deg,var(--bg-gray),#e8e8e8);display:flex;align-items:center;justify-content:center;color:var(--text-light);font-size:13px;width:100%}

/* Content cards (page sections) */
.content-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px}
.content-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-light);border:1px solid var(--border-light);border-radius:6px;text-decoration:none;color:inherit;transition:all .2s}
.content-card:hover{border-color:var(--primary);background:#fff}
.content-card--link{cursor:pointer}
.content-card--link:hover{box-shadow:0 2px 8px rgba(210,40,46,.1);border-color:var(--primary)}
.content-card--link:hover .content-card-arrow{color:var(--primary);transform:translateX(3px)}
.content-card-img{width:80px;height:56px;flex-shrink:0;border-radius:4px;overflow:hidden;background:var(--bg-gray)}
.content-card-img img{width:100%;height:100%;object-fit:cover}
.content-card-body{flex:1;min-width:0}
.content-card-body h4{font-size:14px;font-weight:500;color:var(--text-black);line-height:1.5;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.content-card-body p{font-size:12px;color:var(--text-gray);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.content-card-arrow{flex-shrink:0;font-size:16px;color:var(--text-light);transition:all .2s}

/* Image loading skeleton */
.img-skeleton{position:absolute;inset:0;background:linear-gradient(90deg,var(--bg-gray) 25%,#e8e8e8 50%,var(--bg-gray) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:12px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Login page */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--primary)}
.login-box{background:#fff;padding:40px 48px;width:400px}
.login-box h2{font-size:22px;font-weight:700;color:var(--primary-dark);margin-bottom:6px;letter-spacing:2px}
.login-box p{font-size:12px;color:var(--text-gray);margin-bottom:28px}
.login-box .form-group input{width:100%;padding:10px 14px;border:1px solid var(--border);font-size:14px;font-family:inherit;outline:none}
.login-box .form-group input:focus{border-color:var(--primary)}
.login-box .form-group label{display:block;font-size:13px;font-weight:500;color:#555;margin-bottom:6px}
.login-box .btn-login{width:100%;padding:11px;background:var(--primary);color:#fff;border:none;font-size:15px;font-family:inherit;cursor:pointer;margin-top:8px}
.login-box .btn-login:hover{background:var(--primary-dark)}

/* Responsive */
@media(max-width:1024px){
  .layout{flex-direction:column}
  .layout .side{width:100%}
  .icon-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .data-row{grid-template-columns:repeat(2,1fr)}
  .admin-stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .navbar .w{flex-wrap:wrap}
  .navbar a{padding:10px 0;font-size:13px}
  .nav-toggle{display:flex}
  .nav-menu{display:none;width:100%;flex-direction:column;flex:none}
  .nav-menu.open{display:flex}
  .two-col,.icon-grid,.card-grid{grid-template-columns:1fr}
  .data-row{grid-template-columns:1fr 1fr}
  .slide-img{min-height:220px}
  .header .w{flex-direction:column;gap:10px}
  .search-box input{width:140px}
  .admin-sidebar{width:0;overflow:hidden}
  .admin-main{margin-left:0}
}

