*{margin:0;padding:0;box-sizing:border-box}:root{--bg-main: #fff6ea;--bg-soft: #fff1de;--bg-card: rgba(255, 252, 247, .9);--bg-chip: #fff8ef;--line: rgba(141, 86, 42, .12);--text-main: #4a2f1f;--text-sub: #7d5a42;--brand: #e98332;--brand-deep: #cf6b1e;--brand-soft: #ffb36f;--success: #2f9e65;--danger: #cf3f3f;--radius-xl: 24px;--radius-lg: 18px;--radius-md: 12px;--shadow-soft: 0 10px 30px rgba(155, 89, 36, .1);--shadow-hover: 0 14px 30px rgba(155, 89, 36, .16)}body{font-family:PingFang SC,Microsoft YaHei,sans-serif;color:var(--text-main);background:radial-gradient(1200px 500px at 20% -10%,rgba(255,208,150,.45),transparent 70%),radial-gradient(1100px 500px at 90% 0%,rgba(255,166,111,.25),transparent 70%),linear-gradient(180deg,var(--bg-main) 0%,#ffe9cf 100%);min-height:100vh}.main-content{width:min(1400px,calc(100% - 48px));margin:0 auto 24px;display:grid;grid-template-columns:1fr 1.2fr;gap:20px}.app-header,.map-section,.restaurant-section{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft)}.app-header{width:min(1400px,calc(100% - 48px));margin:24px auto 20px;padding:24px}.header-title{text-align:center;margin-bottom:16px}.app-title{display:inline-flex;align-items:center;gap:10px;font-size:40px;line-height:1.1;color:var(--brand-deep);font-weight:800}.title-icon{font-size:44px}.app-subtitle{color:var(--text-sub);margin-top:8px;font-size:16px}.auth-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff8ee;border:1px solid var(--line);border-radius:16px;padding:14px 16px}.auth-bar.offline{background:#fff6ec}.auth-status-copy strong{font-size:15px}.auth-status-copy p{margin-top:3px;color:var(--text-sub);font-size:13px}.auth-actions{display:flex;gap:10px}.status-btn,.random-btn,.add-btn,.primary-btn,.secondary-btn,.action-btn{border:none;border-radius:999px;cursor:pointer;font-weight:600;transition:all .2s ease}.status-btn,.random-btn,.primary-btn{color:#fff;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%)}.status-btn:hover,.random-btn:hover,.primary-btn:hover,.add-btn:hover,.secondary-btn:hover,.action-btn:hover{transform:translateY(-1px)}.status-btn{padding:9px 14px;font-size:14px}.status-btn.ghost,.add-btn,.secondary-btn,.action-btn{background:#fff;color:var(--brand-deep);border:1px solid rgba(207,107,30,.2)}.header-search{margin-top:16px;display:grid;grid-template-columns:1fr auto;gap:12px}.search-box{position:relative}.search-box input{width:100%;border:1px solid var(--line);border-radius:999px;background:#fff;padding:12px 44px 12px 16px;font-size:14px;color:var(--text-main)}.search-box input:focus{outline:none;border-color:#e9833299}.search-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%)}.action-buttons{display:flex;gap:10px}.random-btn,.add-btn{padding:12px 16px;font-size:14px;display:inline-flex;align-items:center;gap:6px}.header-filters{margin-top:16px;display:grid;grid-template-columns:1fr;gap:12px}.filter-group{background:#fffaf3;border:1px solid var(--line);border-radius:var(--radius-md);padding:12px}.filter-title{font-size:14px;color:var(--text-sub);margin-bottom:8px}.filter-buttons{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{border:1px solid var(--line);background:#fff;color:var(--text-main);border-radius:999px;padding:7px 11px;font-size:13px;cursor:pointer}.filter-btn.active{border-color:transparent;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);color:#fff}.map-section,.restaurant-section{padding:18px}.section-header{display:flex;justify-content:space-between;margin-bottom:12px}.section-title{font-size:20px}.count{color:var(--text-sub);font-size:14px;font-weight:500}.wuhan-map-wrapper{background:linear-gradient(180deg,#fff8ef,#ffeed8);border-radius:var(--radius-lg);border:1px solid var(--line);padding:14px}.wuhan-map-dream{position:relative;min-height:500px;border-radius:14px;overflow:hidden;background:radial-gradient(circle at 20% 20%,rgba(255,191,128,.45),transparent 35%),radial-gradient(circle at 80% 30%,rgba(255,173,115,.35),transparent 30%),linear-gradient(135deg,#fff7ea,#ffe6c8)}.map-glow{position:absolute;border-radius:999px;filter:blur(24px);opacity:.4}.map-glow--one{width:180px;height:180px;background:#ffb069;left:-50px;top:40px}.map-glow--two{width:220px;height:220px;background:#ff8f58;right:-70px;bottom:-30px}.district-node{position:absolute;transform:translate(-50%,-50%);border:1px solid rgba(207,107,30,.2);background:#ffffffd9;border-radius:14px;padding:8px 10px;min-width:100px;text-align:left;cursor:pointer;z-index:2}.district-node strong{display:block;font-size:13px}.district-node span{display:block;font-size:12px;color:var(--text-sub)}.district-node.active{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);color:#fff;border-color:transparent}.district-node.active span{color:#ffffffdb}.hotspot-bubble{position:absolute;transform:translate(-50%,-50%);border:1px solid rgba(233,131,50,.3);border-radius:999px;padding:6px 10px;font-size:12px;background:#ffffffe6;color:var(--text-main);cursor:pointer;box-shadow:0 4px 10px #7d5a4226;animation:floatBubble 3s ease-in-out infinite}.hotspot-bubble.active{color:#fff;border-color:transparent;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%)}@keyframes floatBubble{0%,to{transform:translate(-50%,-50%) translateY(0)}50%{transform:translate(-50%,-50%) translateY(-3px)}}.district-info{margin-top:12px;background:#fffaf2;border:1px solid var(--line);border-radius:12px;padding:10px 12px}.district-info h3{font-size:15px;margin-bottom:4px}.district-info p{font-size:13px;color:var(--text-sub)}.restaurant-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.restaurant-card{border:1px solid var(--line);border-radius:16px;background:#fff;overflow:hidden;box-shadow:var(--shadow-soft);cursor:pointer}.restaurant-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.card-image{position:relative;height:170px}.card-image img{width:100%;height:100%;object-fit:cover}.card-badges{position:absolute;left:8px;top:8px;display:flex;gap:6px}.badge{border-radius:999px;padding:4px 8px;font-size:11px;color:#fff}.badge.official{background:#e37a2b}.badge.private{background:#252525ad}.favorite-btn{position:absolute;right:8px;top:8px;width:34px;height:34px;border-radius:999px;border:none;background:#ffffffe6;cursor:pointer}.favorite-btn.active{background:#ff5a5f;color:#fff}.card-content{padding:12px;display:grid;gap:7px}.restaurant-name{font-size:17px}.restaurant-meta,.restaurant-address,.restaurant-distance{font-size:13px;color:var(--text-sub)}.price-rating-row{display:flex;gap:8px;flex-wrap:wrap}.price-pill,.rating-pill{padding:4px 9px;border-radius:999px;font-size:12px;border:1px solid var(--line);background:#fff8ef}.restaurant-tags,.tag-list,.dishes-list{display:flex;gap:6px;flex-wrap:wrap}.tag{background:#ffe8cf;color:#865226;border-radius:999px;padding:4px 9px;font-size:12px}.dish-item{background:#ffe2d0;color:#91573b;border-radius:999px;padding:4px 9px;font-size:12px}.map-nav-btn{margin-top:4px;border:none;border-radius:12px;background:linear-gradient(135deg,#49a970,#2f8d59);color:#fff;padding:9px 10px;font-size:13px;cursor:pointer}.empty-state{border:1px dashed var(--line);background:#fffbf6;border-radius:14px;text-align:center;padding:32px 18px;color:var(--text-sub)}.empty-icon{font-size:34px;display:block;margin-bottom:6px}.detail-drawer,.personal-drawer,.edit-modal,.auth-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000075;z-index:1200}.detail-drawer,.personal-drawer{display:flex;justify-content:flex-end}.drawer-content,.modal-content,.auth-card{background:#fffaf3;border-left:1px solid var(--line);box-shadow:var(--shadow-soft)}.drawer-content{width:min(560px,100%);height:100%;overflow-y:auto;position:relative}.drawer-close,.close-btn{width:36px;height:36px;border-radius:999px;border:none;background:#fff;cursor:pointer}.drawer-close{position:absolute;right:14px;top:14px;z-index:2}.image-gallery{height:280px;background:#f2f2f2}.main-image{width:100%;height:100%;object-fit:cover}.image-nav{position:absolute;left:50%;bottom:14px;transform:translate(-50%);background:#0000008c;color:#fff;border-radius:999px;padding:6px 10px;display:flex;align-items:center;gap:10px}.image-nav button{border:none;background:transparent;color:inherit;cursor:pointer}.drawer-body{padding:16px;display:grid;gap:14px}.detail-header{display:grid;gap:10px}.drawer-title{font-size:24px}.detail-actions{display:flex;gap:8px;flex-wrap:wrap}.action-btn{padding:8px 12px}.action-btn.active,.action-btn.edit{color:#fff;border:none;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%)}.action-btn.delete{color:var(--danger);border-color:#cf3f3f4d;background:#fff1f1}.info-section{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px}.info-row{display:flex;gap:10px;padding:5px 0}.info-label{width:70px;color:var(--text-sub);font-size:13px}.info-value{flex:1;font-size:14px}.rating-section{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px}.rating-section h4{margin-bottom:6px}.rating-summary strong{font-size:22px;color:var(--brand-deep)}.rating-summary span{margin-left:4px;font-size:13px;color:var(--text-sub)}.rating-stars{margin-top:8px;display:flex;gap:4px}.star-btn{border:none;background:#f4e8d8;color:#b5865f;width:34px;height:34px;border-radius:10px;font-size:18px;cursor:pointer}.star-btn.active{background:#ffb865;color:#fff}.list-attach-section{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px}.list-attach-row{margin-top:8px;display:grid;grid-template-columns:1fr auto;gap:8px}.list-attach-row select,.list-creator input,.form-group input,.form-group textarea,.form-group select{border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--text-main);padding:10px 12px;font-size:14px}.edit-modal,.auth-modal{display:flex;align-items:center;justify-content:center;padding:16px}.modal-content{width:min(760px,100%);max-height:calc(100vh - 24px);border-radius:var(--radius-xl);overflow:hidden}.modal-content--wide{width:min(860px,100%)}.auth-card{width:min(460px,100%);border-radius:var(--radius-xl)}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--line);padding:14px 16px}.modal-subtitle,.auth-card-subtitle{margin-top:4px;color:var(--text-sub);font-size:13px}.edit-form{padding:14px 16px 18px;max-height:calc(100vh - 120px);overflow-y:auto;display:grid;gap:10px}.compact-grid{display:grid;gap:10px}.compact-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-group{display:grid;gap:5px}.form-group label{font-size:13px;color:var(--text-sub)}.form-label-row{display:flex;justify-content:space-between;gap:10px;align-items:baseline}.field-hint,.visibility-note,.auth-helper{font-size:12px;color:var(--text-sub)}.upload-area{border:1px dashed rgba(207,107,30,.35);border-radius:12px;background:#fff9f0;padding:14px;cursor:pointer}.upload-placeholder{text-align:center;color:var(--text-sub)}.upload-icon{display:block;font-size:28px;margin-bottom:4px}.image-preview-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.preview-item{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:1}.preview-item img{width:100%;height:100%;object-fit:cover}.remove-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:999px;border:none;background:#cf3f3fe6;color:#fff;cursor:pointer}.add-more{aspect-ratio:1;border-radius:10px;border:1px dashed var(--line);display:flex;align-items:center;justify-content:center;color:var(--brand-deep);background:#fff}.radio-group{display:grid;gap:10px}.visibility-options--compact{grid-template-columns:repeat(2,minmax(0,1fr))}.radio-label{display:flex;gap:8px;border:1px solid var(--line);border-radius:12px;padding:10px;background:#fff}.visibility-card.active{border-color:#e9833299;background:#fff4e4}.radio-text{display:grid;gap:2px}.radio-text strong{font-size:13px}.radio-text small{font-size:12px;color:var(--text-sub)}.form-actions{display:flex;gap:10px}.primary-btn,.secondary-btn{flex:1;padding:10px 12px}.auth-tabs{padding:0 16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.auth-tab{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px;cursor:pointer}.auth-tab.active{border:none;color:#fff;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%)}.drawer-header--panel{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line)}.dashboard-strip{padding:12px 16px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;border-bottom:1px solid var(--line)}.dashboard-card{border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px}.dashboard-card strong{font-size:18px;color:var(--brand-deep)}.dashboard-card span{display:block;color:var(--text-sub);font-size:12px;margin-top:4px}.tabs{padding:10px 16px;display:flex;gap:8px;flex-wrap:wrap;border-bottom:1px solid var(--line)}.tab-btn{border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 10px;cursor:pointer;font-size:13px;color:var(--text-main)}.tab-btn.active{border:none;color:#fff;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%)}.tab-content{padding:14px 16px 24px;display:grid;gap:10px}.restaurant-list{display:grid;gap:8px}.restaurant-card.mini{display:grid;grid-template-columns:70px 1fr;gap:10px;align-items:start;padding:10px}.restaurant-card.mini img{width:70px;height:70px;object-fit:cover;border-radius:10px}.card-info{display:grid;gap:4px}.card-info h4{font-size:14px}.card-info p{font-size:12px;color:var(--text-sub)}.visibility-badge{display:inline-block;width:fit-content;padding:3px 8px;border-radius:999px;font-size:11px}.visibility-badge.private{background:#f0f0f0}.visibility-badge.public{background:#e5f4eb;color:var(--success)}.mini-card-actions{margin-top:4px}.mini-delete-btn{border:1px solid rgba(207,63,63,.3);background:#fff3f3;color:var(--danger);border-radius:999px;padding:4px 9px;font-size:12px;cursor:pointer}.lists-panel{display:grid;gap:10px}.list-creator{border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px;display:grid;gap:8px}.list-grid{display:flex;gap:8px;flex-wrap:wrap}.list-chip{border:1px solid var(--line);background:#fff;color:var(--text-main);border-radius:999px;padding:6px 10px;font-size:12px;cursor:pointer}.list-chip.active{border:none;color:#fff;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%)}.selected-list{border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px;display:grid;gap:10px}.selected-list-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.selected-list-header h4{font-size:16px}.selected-list-header p{font-size:12px;color:var(--text-sub);margin-top:4px}.personal-btn{position:fixed;right:16px;bottom:16px;width:56px;height:56px;border-radius:999px;border:none;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);color:#fff;box-shadow:0 10px 20px #9b59244d;cursor:pointer;z-index:1100}.toast{position:fixed;left:50%;bottom:22px;transform:translate(-50%);background:#2f2f2f;color:#fff;padding:10px 14px;border-radius:999px;font-size:13px;z-index:1300}.toast.success{background:#2f9e65}.toast.error{background:#cf3f3f}.slide-enter-active,.slide-leave-active,.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.slide-enter-from,.slide-leave-to,.fade-enter-from,.fade-leave-to{opacity:0}@media(max-width:1200px){.main-content{grid-template-columns:1fr}}@media(max-width:900px){.app-header,.main-content{width:calc(100% - 24px)}.app-title{font-size:30px}.header-search,.compact-grid--two,.visibility-options--compact,.restaurant-grid{grid-template-columns:1fr}.dashboard-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.image-preview-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:640px){.app-header{padding:16px;margin-top:12px}.app-title{font-size:26px}.auth-bar{flex-direction:column;align-items:stretch}.status-btn{width:100%}.wuhan-map-dream{min-height:430px}.district-node{min-width:92px;padding:7px 8px}.hotspot-bubble{font-size:11px;padding:5px 8px}.drawer-title{font-size:20px}.dashboard-strip{grid-template-columns:1fr 1fr}}
