:root{--bg:#f7f7fb;--text:#111827;--muted:#6b7280;--primary:#111827;--brand:#0ea5e9;--card:#ffffff;--border:#e5e7eb;--accent:#2563eb}
*{box-sizing:border-box}html,body{padding:0;margin:0}
html,body{height:100%}
body{background:var(--bg);color:var(--text);font:14px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,"Noto Sans",sans-serif;overflow:hidden;padding-top:70px}
.page-editor{padding-top:0}
.container{max-width:none;width:100%;margin:0}
.site-header{position:fixed;top:0;left:0;right:0;background:#2c4360;border-bottom:1px solid var(--border);z-index:100}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{font-weight:700;font-size:30px;margin-left:0;color:#fff}
.page-login .login-hero .brand{color:#2c4360;font-style:italic}
.site-header a{color:#fff;text-decoration:none}
.menu-btn{display:none;align-items:center;justify-content:center;width:50px;height:50px;border:none;border-radius:8px;background:transparent;color:#fff;cursor:pointer}
.mobile-nav-bar{display:none}
.main-nav a{color:var(--text);text-decoration:none;margin-left:16px}
.header-inner{gap:12px}
.right-actions{display:flex;align-items:center;gap:8px;margin-right:16px}
.left-actions{display:none}
.header-search{display:flex;gap:8px;max-width:300px;align-items:center;align-self:center;justify-content:space-evenly}
.header-search input{flex:1;height:35px;border:1px solid var(--border);border-radius:20px;padding:8px;font-size:16px}
.search-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--accent);background:var(--accent);color:#fff;cursor:pointer;padding:0;box-sizing:border-box;line-height:0;flex-shrink:0}
.search-btn:hover{filter:brightness(1.05)}
.search-btn .icon{width:20px;height:20px}
.search-input-group{position:relative;display:flex;align-items:center}
.search-input-group input{padding-right:34px;width:100%;border:1px solid var(--border);border-radius:20px;background:#fff;padding:8px 12px}
.clear-search-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:transparent;color:var(--muted);font-size:18px;line-height:1;cursor:pointer;display:none;padding:0}
.search-input-group input:not(:placeholder-shown)+.clear-search-btn{display:inline}
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:nowrap}
.toolbar .search-input-group{flex:1}
.toolbar input{height:36px}
.toolbar .btn{height:36px;line-height:36px;padding:0 16px;border-radius:20px}
.pwd-input-group{position:relative}
.pwd-input-group input{width:100%;padding-right:60px;display:block}
.toggle-password-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:transparent;color:var(--muted);width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;line-height:0;cursor:pointer;padding:0}
.user-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--accent);background:var(--accent);color:#fff;cursor:pointer;padding:0;box-sizing:border-box;line-height:0;flex-shrink:0}
.user-btn:hover{filter:brightness(1.05)}
.user-btn .icon{width:20px;height:20px}
.user-btn.logged{background:#06b6d4;border-color:#06b6d4}
.home-btn{display:none}
.home-btn .icon{filter:brightness(0) invert(1)}
.hero{padding:20px;background:#fff;border-bottom:1px solid var(--border)}
.hero h1{margin:0;font-size:22px}
.search-bar{display:flex;gap:8px}
.hero .search-bar{display:none}
.search-bar input{flex:1;height:40px;border:1px solid var(--border);border-radius:20px;padding:12px;font-size:18px}
.news-highlight .news-card{background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 6px 20px rgba(16,24,40,.06);padding:12px;margin:12px;display:flex;gap:12px;align-items:flex-start}
.news-highlight .news-card.news-link{color:inherit;text-decoration:none}
.news-highlight .news-card a{display:block;flex-shrink:0}
.news-highlight .news-img{width:280px;height:auto;border-radius:10px;display:block;object-fit:cover}
.news-highlight .news-title{font-size:18px;font-weight:900;margin-bottom:6px;color:#000;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;line-height:1.4}
.news-highlight .news-content{margin-top:0;color:var(--text);flex:1}
.news-highlight .news-content{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:7;overflow:hidden;line-height:1.6}
.news-highlight .news-body{flex:1;display:flex;flex-direction:column}
.news-highlight .news-meta{margin-top:8px;color:var(--muted);font-size:13px;display:flex;gap:8px;align-items:center}
.news-highlight .news-meta .sep{opacity:.5}
.news-highlight .news-actions{margin-top:8px}
.cat-scroller{padding:12px 0;background:#fff;border-bottom:1px solid var(--border)}
.cat-scroll{display:flex;gap:12px;overflow-x:auto;padding:0 16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.cat-scroll::-webkit-scrollbar{display:none}
.cat-card{flex:0 0 auto;min-width:180px;border:1px solid var(--border);border-radius:12px;background:#fff;box-shadow:0 6px 20px rgba(16,24,40,.06);padding:10px 12px;display:flex;align-items:center;gap:10px;scroll-snap-align:start}
.cat-card .icon{width:22px;height:22px;color:var(--accent)}
.cat-card .name{font-weight:600}
.cat-card .count{margin-left:auto;color:#0f766e;background:#e7f7f5;border-radius:999px;padding:0 8px;height:22px;line-height:22px;font-size:12px}
.btn{display:inline-block;height:40px;line-height:40px;padding:0 14px;border-radius:20px;border:1px solid var(--border);background:#fff;color:var(--text);text-decoration:none}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.outline{background:#fff;color:var(--accent);border-color:var(--accent)}
.btn.full{width:100%}
.login-form .btn{display:inline-flex;align-items:center;justify-content:center}
.btn.danger{background:#ef4444;border-color:#ef4444;color:#fff}
.btn.danger:hover{filter:brightness(1.05)}
.search-tip{margin-top:8px;color:var(--muted)}
.biz-scroller{padding:8px 0;border-bottom:1px solid var(--border)}
.biz-scroll{display:flex;gap:12px;overflow-x:auto;padding:0 16px;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;touch-action:pan-x}
.biz-scroll::-webkit-scrollbar{display:none}
.biz-card{flex:0 0 auto;width:130px;aspect-ratio:2/3;border:1px solid var(--border);border-radius:12px;background:#fff;box-shadow:0 6px 20px rgba(16,24,40,.06);padding:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--text)}
.biz-card .avatar{width:90px;height:90px;border-radius:50%;object-fit:cover;background:#f1f5f9;flex-shrink:0}
.biz-card .title{font-weight:600;color:var(--primary);text-align:center;margin-top:2px;line-height:1.1}
.biz-card.blank{pointer-events:none}
.biz-card .mini-badge{display:inline-block;margin-left:6px;font-size:12px;color:#16a34a}
.section{padding:0 0}
.section-title{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--primary)}
.grid{display:grid}
.grid.cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.grid.biz-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.table-wrap{width:100%;margin-bottom: 50px;overflow-x:auto}
.biz-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 6px 20px rgba(16,24,40,.06)}
.biz-table thead th{position:sticky;top:0;background:#f8fafc;color:var(--muted);text-align:left;font-weight:600;padding:12px;border-bottom:1px solid var(--border)}
.biz-table tbody td{padding:12px;border-bottom:1px solid var(--border);vertical-align:middle}
.biz-table tbody tr:hover{background:#f9fafb}
.biz-title-cell{display:flex;align-items:center;gap:8px;cursor:pointer}
.biz-name-wrapper{display:flex;flex-direction:column;justify-content:center}
.biz-cn-name{display:block;font-size:13px;font-weight:600;margin-bottom:2px;color:var(--text)}
.biz-actions-cell{white-space:nowrap}
.layout{display:grid;grid-template-columns:300px 1fr;grid-template-rows:auto 1fr;height:calc(100vh - 70px - 50px);overflow:hidden;margin-top:0}
.page-editor .layout{height:calc(100vh - 50px)}
.sidebar-brand{grid-column:1;grid-row:1}
.sidebar{grid-column:1;grid-row:2}
.main{grid-column:2;grid-row:1 / span 2}
.page-card-editing .main{grid-column:1;grid-row:1 / span 2}
.sidebar{align-self:start;position:relative;top:auto;height:100%;padding: 20px 15px 20px;background-color: #dfe7f1;;overflow-y:auto}
.main{height:100%;overflow-y:auto;padding: 30px}
.main.centered{grid-column:1;width:100%;display:grid;place-items:center;min-height:calc(100vh - 70px - 50px);padding-bottom:80px}
.main.centered .section{width:100%;max-width:none;margin:0}
.main.centered{display:grid;place-items:center;min-height:calc(100vh - 70px - 50px);padding-bottom:80px}
.main.centered .section{width:100%;max-width:960px}
.page-service .main.centered .section{width:100%;max-width:960px;margin:0 auto}
.page-service .layout{grid-template-columns:1fr}
.page-service .main{grid-column:1;grid-row:1 / span 2}
.page-news-view .layout{grid-template-columns:1fr}
.page-news-view .main{grid-column:1;grid-row:1 / span 2}
.page-news-view .main.centered .section{width:100%;max-width:560px;margin:0 auto}
.page-news-view .news-content{width:100%;max-width:560px;margin:0 auto;padding:0 10px}
.page-news-view .detail-value img{width:100%;height:auto;display:block;border-radius:12px}
.page-news-view .news-figure,
.page-editor .news-figure{margin:0}
.page-news-view .news-figure img,
.page-editor .news-figure img{width:100%;height:auto;display:block;border-radius:12px}
.news-img-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:15px 0}
.news-img-grid img{width:100%;border-radius:8px;object-fit:cover;aspect-ratio:4/3}
.triple-image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:15px 0}
.triple-image-grid img{width:100%;border-radius:8px;object-fit:cover;aspect-ratio:4/3}
.two-cols{display:flex;gap:16px;align-items:stretch}
.two-cols > *{flex:1 1 0}
.page-businesses .two-cols{max-width:960px;margin:0 auto}
.side-cat-item{display:flex;align-items:center;justify-content:space-between;text-decoration:none;color:var(--text);padding:10px 12px;border:1px solid var(--border);border-radius:20px;margin:5px;background:#fff}
.page-editor .sidebar{display:flex;flex-direction:column}
.page-editor .sidebar-spacer{flex:1 1 auto}
.page-editor .account-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.page-editor .account-row .detail-value{flex:1}
.side-cat-item.active{outline:2px solid var(--accent);background:#f8fafc}
.side-cat-name{font-weight:600}
.side-cat-count{color:#0f766e;background:#e7f7f5;border-radius:999px;padding:0 8px;height:22px;line-height:22px;font-size:12px}
.card{background:var(--card);border-radius:12px;box-shadow:0 6px 20px rgba(16,24,40,.06);padding:16px;margin:10px 0 10px;border:1px solid var(--border)}
.cat-card{display:block;text-decoration:none;color:var(--text)}
.cat-card.active{outline:2px solid var(--accent)}
.cat-name{font-weight:600;margin-bottom:6px}
.cat-count{color:var(--muted)}
.biz-title{display:flex;align-items:center;gap:8px;font-weight:600;margin-bottom:8px}
.biz-link{color:var(--primary);text-decoration:none}
.page-home #list .biz-table .biz-link{font-weight:600}
.verified-badge{display:inline-block}
.verified-badge img{width:20px;height:20px;vertical-align:middle;filter:invert(35%) sepia(92%) saturate(600%) hue-rotate(85deg) brightness(92%) contrast(90%)}
.verified-badge.red img{filter:invert(27%) sepia(51%) saturate(2878%) hue-rotate(346deg) brightness(104%) contrast(97%)}
.verified-days{color:#16a34a;font-size:12px}
.biz-meta{display:flex;gap:12px;color:var(--muted);margin-bottom:10px;flex-wrap:wrap}
.biz-actions{display:flex;gap:8px;flex-wrap:wrap}
.biz-phone-link{color:var(--primary);text-decoration:none}
.biz-phone-link:hover{color:var(--accent);text-decoration:underline}
.verified-modules{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.vm-item{display:inline-block}
.vm-item input{display:none}
.vm-box{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border:1px solid var(--border);border-radius:12px;background:#fff}
.vm-box .icon{width:36px;height:36px}
.vm-item input:checked + .vm-box{outline:2px solid var(--accent);background:#f8fafc}
.slug-row{display:flex;gap:8px;align-items:center;margin-top:6px}
.slug-host{color:var(--muted)}
.slug-preview{color:var(--primary);font-weight:600}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;height:40px;width:40px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text);text-decoration:none}
.icon-btn.outline{color:var(--accent);border-color:var(--accent);background:#fff}
.icon-btn.circle{width:36px;height:36px;border-radius:50%}
.icon-btn.danger{background:#ef4444;border-color:#ef4444;color:#fff}
.icon-btn.danger:hover{filter:brightness(1.05)}
.icon{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;display:block}
.icon{stroke-linecap:round;stroke-linejoin:round}
.fa.icon{display:inline-block;font-size:20px;line-height:1}
.icon-btn:hover{border-color:var(--accent);color:var(--accent);background:#f0f7ff}
.icon-link{display:inline-flex;align-items:center;justify-content:center;    margin: 0 5px;width:24px;height:24px;color:var(--muted);text-decoration:none}
.icon-link .fa{font-size:20px}
.icon-link:hover{color:var(--accent)}
.icon-fill path{fill:currentColor !important;stroke:none !important}
.sidebar-mask{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;z-index:140}
.sidebar-mask.show{display:block}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;padding:16px;z-index:300;overflow-y:auto}
.modal-overlay.show{display:flex}
.modal{max-width:880px;width:100%;background:#fff;border-radius:12px;box-shadow:0 10px 25px rgba(0,0,0,.15);padding: 20px;border:1px solid var(--border);max-height:calc(100vh - 80px);overflow-y:auto}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}
.card-title{font-size:16px;color:var(--primary);font-weight:600}
.modal-close{height:28px;width:28px;border:none;border-radius:8px;background:#f1f5f9;color:#111;cursor:pointer}
.modal-body{padding:16px}
.pv-cover{width:100%;margin-bottom:12px;display:flex;justify-content:center}
.pv-cover .cover-box{width:min(320px,100%);aspect-ratio:16/9;border-radius:12px;border:1px solid var(--border);background:#f1f5f9;overflow:hidden}
.pv-cover .cover-img{width:100%;height:100%;object-fit:cover;display:block}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.editor-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-top:15px}
.controls-card{padding:16px}
.controls-tabs{display:flex;gap:8px;margin-bottom:12px}
.controls-tabs .tab{display:inline-block;height:36px;line-height:36px;padding:0 12px;border:1px solid var(--border);border-radius:20px;background:#fff;color:var(--text);cursor:pointer}
.controls-tabs .tab.active{background:var(--accent);border-color:var(--accent);color:#fff}
.color-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.form-row input[type="file"]::file-selector-button{height:32px;line-height:32px;padding:0 12px;border:1px solid var(--accent);border-radius:16px;background:var(--accent);color:#fff;cursor:pointer;margin-right:10px}
.form-row input[type="file"]::file-selector-button:hover{filter:brightness(1.05)}
.upload-row{margin-top:4px}
.upload-box{width:100%;height:50px;border:2px dashed var(--border);border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--muted);cursor:pointer}
.upload-box:hover{border-color:var(--accent);background:#f8fafc;color:var(--accent)}
.upload-label{font-size:14px}
.upload-filename{margin-top:8px}
/* delete button overlay for upload rows */
.upload-row{position:relative}
.upload-row .del-btn{position:absolute;right:6px;top:6px;z-index:2}
.form-row{display:flex;flex-direction:column;gap:6px;margin:5px}
.form-row label{color:var(--muted);font-size:15px}
.form-row input,.form-row textarea,.form-row select{border:1px solid var(--border);border-radius:20px;padding:8px 10px;font-size:14px;background:#fff;width:100%}
.form-row textarea{min-height:96px;resize:vertical}
.detail-value{color:var(--text);font-size:14px;word-break:break-word}
.page-editor .form .detail-value.create-inline{display:flex;align-items:center;justify-content:space-between;gap:8px}
.page-editor .news-content .detail-value,
.page-news-view .news-content .detail-value{}
.page-editor .news-content .detail-value.divider-top,
.page-news-view .news-content .detail-value.divider-top{border-top:1px solid var(--border);padding-top:8px;margin-top:8px}
.hidden{display:none !important}
.actions.right{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}
.actions.right #pv_download_vcf{order:-1}
.actions.right .download-label{order:-2;align-self:center;color:var(--muted)}
.modal .actions .icon-link{width:32px;height:32px}
.modal .actions .icon{width:35px;height:35px}
.site-footer{position:fixed;left:0;right:0;bottom:0;background:#2c4360;color:#fff;height:50px;z-index:90}
.footer-inner{display:flex;align-items:center;justify-content:center;height:100%}
.brand-mark{font-weight:700;font-style:italic}
.site-footer a{color:#fff;text-decoration:none}
.side-cat-left {display:flex;align-items:center;gap:10px}
.side-icon {width:18px;height:18px;color:var(--muted);flex-shrink:0}
.fa.side-icon{font-size:18px;line-height:1}
.side-cat-item.active .side-icon, .side-cat-item:hover .side-icon {color:var(--accent)}
@media (min-width: 1024px){
  .site-header .header-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;justify-content:normal;margin: 0 25px}
  .site-header .brand{margin-left:0;justify-self:start}
  .site-header .header-search{justify-self:center;max-width:560px;width:100%}
  .site-header .right-actions{justify-self:end;margin-right:0}
  .site-header .left-actions{display:none}
}
@media (max-width: 767px){
  .layout{grid-template-columns:1fr;grid-template-rows:auto auto;height:auto}
  body{overflow:auto}
  body{padding: 80px 10px 10px 10px}
  .site-header .brand{display:none}
  .site-header .left-actions{display:flex;align-items:center}
  .editor-layout{grid-template-columns:1fr}
  .page-editor .section{padding:16px 10px}
  .page-editor .news-content{width:100%;max-width:none;margin:0;padding:0 6px}
  .page-editor .section .card{margin:0 8px}
  .page-card-editing .controls-card{padding:12px}
  .page-card-editing .controls-card .controls-tabs{position:sticky;bottom:0;left:0;right:0;background:#fff;padding:10px;display:flex;gap:8px;border-top:1px solid var(--border);z-index:60}
  .page-card-editing .controls-card .controls-tabs .btn{flex:1}
  .page-card-editing .template-preview-section{width:100% !important;height:80vh !important;border-radius:50px !important;border-width:8px !important}
  .page-card-editing .template-preview-section iframe{height:auto !important;min-height:420px}
  .page-card-editing .edit-header-bar{flex-direction:column;justify-content:flex-start !important;align-items:flex-start !important;gap:8px}
  .page-card-editing .edit-header-right{flex-direction:column;align-items:flex-start !important;gap:6px}
  .page-businesses .edit-header-bar{flex-direction:column;justify-content:flex-start !important;align-items:flex-start !important;gap:8px}
  .page-businesses .edit-header-right{flex-direction:column;align-items:flex-start !important;gap:6px}
  /* 头部在手机端与桌面端一致：不做布局重写 */
  .two-cols{flex-direction:column}
  .sidebar{position:fixed;top:0;left:0;width:100vw;height:calc(100vh - 30px);background:#fff;border-right:1px solid var(--border);box-shadow:0 8px 30px rgba(0,0,0,.2);padding:20px 20px 100px;z-index:150;overflow-y:auto;transform:translateX(-100%);opacity:0;visibility:hidden;pointer-events:none;transition:transform .6s cubic-bezier(.22,.61,.36,1),opacity .6s ease}
  .sidebar.open{display:block;transform:translateX(0);opacity:1;visibility:visible;pointer-events:auto}
  body.no-scroll{overflow:hidden}
  .main{grid-column:1;padding:0 0 150px}
  .brand{font-size:22px;margin-left:10px}
  .right-actions{margin-right:25px; margin-left:auto; justify-content:flex-end}
  .hero{padding:24px}
  .page-login .header-inner,
  .page-businesses .header-inner{justify-content:space-between}
  .page-login .right-actions,
  .page-businesses .right-actions{margin-right:25px; margin-left:auto; justify-content:flex-end}
  .page-login .home-btn,
  .page-businesses .home-btn,
  .page-card-editing .home-btn{display:inline-flex;margin-left:25px}
  .search-bar{flex-direction:row;align-items:center}
  .hero .search-bar{display:none}
  .search-section{display:none}
  .search-bar input {padding:10px; height: 45px;}
  .header-search input{margin-left:25px}
  .btn {height: 45px;line-height: 45px;padding: 0px 20px;border-radius: 25px;font-size: 16px;
;}
  .news-highlight .news-card{margin:8px 8px 12px;flex-direction:column}
  .news-highlight .news-img{width:100%}
  .news-highlight .news-meta{font-size:12px}
  .search-bar .search-submit{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--accent);background:var(--accent);color:#fff;padding:0;box-sizing:border-box;line-height:0;flex-shrink:0}
@media (min-width: 1024px){
  .site-header .header-inner{
    display:grid;
    grid-template-columns:auto 1fr auto;
    justify-content: normal;
    width:100%;
    align-items:center;
    gap:12px;
  }
  .site-header .left-actions{display:none}
  .site-header .brand{margin-left:0 !important;justify-self:start}
  .site-header .header-search{justify-self:center;max-width:none;width:100%}
  .site-header .header-search input{margin-left:0;width:100%}
  .site-header .right-actions{justify-self:end;margin-right:10px}
}
  .search-bar .search-submit{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--accent);background:var(--accent);color:#fff;padding:0;box-sizing:border-box;line-height:0;flex-shrink:0}
  .search-bar .search-submit .icon{width:20px;height:20px}
  .search-bar .search-submit .label{display:none}
  .page-login .main.centered{place-items:start}
  .page-login .section{max-width:560px;margin:0 auto}
  .page-login .login-hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:8px 0 12px}
  .page-login .login-hero .brand{font-size:36px;color:#2c4360;font-style:italic;margin-left:0}
  .page-login .login-hero hr{width:60px;border:0;border-top:3px solid #1e3a8a;opacity:.3;margin:6px 0 10px}
  .page-login .card{margin:0 8px}
  .page-login .form .form-row input,.page-login .form .form-row select{height:40px;font-size:16px;padding:10px 12px}
  .page-login .actions{display:flex;gap:8px;justify-content:space-between;align-items:center}
  .pv-cover{width:100%;margin-bottom:12px}
  .page-editor .detail-value img,
  .page-news-view .detail-value img,
  .page-editor .news-figure img,
  .page-news-view .news-figure img{width:100%;aspect-ratio:16/9;height:auto;object-fit:cover;border-radius:12px}
  .news-table th:nth-child(3),
  .news-table td:nth-child(3){min-width:50px;width:50px;white-space:nowrap}
  .page-editor .section-title,
  .page-news-view .section-title{font-size:18px}

  .col-cn-name, .col-actions {
    display: none;
  }
  .biz-cn-name-mobile {
    display: block;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 2px;
    color: var(--text);
  }
  .menu-btn {
    display: inline-flex;
    background: #1f3045;
    border-radius: 50%;
    width: 70px;
    height: 70px;
    box-shadow: 0 4px 12px rgba(37,99,235,0.3);
    position: absolute;
    top: -30px;
    left: 50%;
    transform: translateX(-50%);
    border: 2px solid #fff;
    z-index: 10;
  }
  .menu-btn .icon {
    width: 36px;
    height: 36px;
    filter: brightness(0) invert(1);
  }
  .page-login .menu-btn{display:none !important}
  .page-businesses .two-cols{flex-direction:column}
  .page-businesses .card{margin:0 8px 12px}
  .page-businesses .section{padding-top:16px}
  .page-businesses .form .grid.two{grid-template-columns:1fr}
  .page-businesses .form .form-row input,
  .page-businesses .form .form-row select,
  .page-businesses .form .form-row textarea{font-size:16px}
  .page-businesses .form .actions{justify-content:flex-end}
  .page-businesses .slug-row{flex-wrap:wrap;align-items:flex-start}
  .page-businesses .slug-row > label{width:100%;margin-bottom:4px}
  .page-businesses .slug-row .slug-host{width:auto;margin-bottom:0;margin-right:6px}
  .page-businesses .slug-row #ecard_slug{max-width:none;flex:1}
  .page-businesses .slug-row #btn_edit_slug,
  .page-businesses .slug-row #btn_create_slug{width:100%;margin-left:0;margin-top:6px;text-align:center}
  .site-footer {
    height: auto;
    display: flex;
    flex-direction: column;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 200;
  }
  .footer-inner {
    height: 85px;
    background: #1f3045;
    align-items: flex-end;
    padding-bottom: 10px;
  }
  .footer-text {
    font-size: 10px;
    padding: 0 10px;
    text-align: center;
    margin-bottom: 10px;
  }
  .page-editor .actions.right.fixed-mobile{position:fixed;left:0;right:0;bottom:95px;padding:10px 16px;background:#fff;border-top:1px solid var(--border);box-shadow:0 -6px 20px rgba(16,24,40,.06);z-index:180;display:flex;gap:8px}
  .page-editor .actions.right.fixed-mobile .btn{flex:1}
}
.orientation-options label{display:flex;align-items:center;width:100%}
.orientation-options label input[type=radio]{margin-left:12px;width:30%}
.color-preview{display:inline-flex;align-items:center;gap:8px;margin-top:6px}
.color-swatch{width:24px;height:24px;border:1px solid var(--border);border-radius:6px;background:#fff;display:inline-block}
.color-value{font-size:12px;color:var(--muted)}
.color-input-wrap{position:relative;display:inline-block;width:100%}
.color-input-wrap input[type=color]{width:100%;height:36px;border-radius:20px;padding:0;-webkit-appearance:none;appearance:none;border:0;background:transparent;box-shadow:none;outline:none;border: 1px solid #cbcbcb;}
.color-input-wrap input[type=color]::-webkit-color-swatch-wrapper{padding:0}
.color-input-wrap input[type=color]::-webkit-color-swatch{border:0;border-radius:20px}
.color-hex-overlay{position:absolute;left:0;top:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:#111827;pointer-events:none}
/* triple image grid for news content */
.page-news-view .triple-image-grid,
.page-editor .triple-image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.page-news-view .triple-image-grid img,
.page-editor .triple-image-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:12px}
