/* 开心小�?- Z-Blog 主题样式 */
*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#FDFBF7;--bg2:#F5F0E8;--card:#FFF;--txt:#3D3D3D;--txt2:#6B6B6B;--muted:#9A9A9A;--green:#6B8E6B;--green2:#8FAF8F;--orange:#C4825A;--border:#E8E4DC;--shadow:0 4px 20px rgba(0,0,0,.06)}
body{font-family:"PingFang SC","Microsoft YaHei",sans-serif;background:var(--bg);color:var(--txt);line-height:1.8}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto}

/* ===== 导航 ===== */
.nav{background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.nav-inner{max-width:1100px;margin:0 auto;padding:0 30px;display:flex;justify-content:space-between;align-items:center;height:70px}
.logo{display:flex;align-items:center;gap:12px}
.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--green),var(--green2));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px}
.logo-text{font-size:22px;font-weight:600}
.logo-text span{color:var(--green)}
.nav-menu{display:flex;gap:8px}
.nav-item a{padding:10px 18px;color:var(--txt2);font-size:15px;border-radius:10px;transition:all .3s;display:flex;align-items:center;gap:6px}
.nav-item a:hover{color:var(--txt);background:var(--bg2)}
.nav-right{display:flex;align-items:center;gap:12px}
.nav-user{font-size:14px;color:var(--txt2)}
.nav-user:hover{color:var(--green)}

/* ===== 按钮 ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:12px;font-size:15px;font-weight:500;transition:all .3s;cursor:pointer;border:none;text-decoration:none}
.btn-orange{background:var(--orange);color:#fff}
.btn-orange:hover{background:#b5724a;transform:translateY(-2px)}
.btn-gray{background:var(--bg2);color:var(--txt)}
.btn-gray:hover{background:var(--border)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:#5a7d5a;transform:translateY(-2px)}
.btn-sm{padding:8px 16px;font-size:13px;border-radius:8px}
.btn-block{display:block;width:100%;text-align:center}

/* ===== 布局 ===== */
.wrap{max-width:1100px;margin:0 auto;padding:40px 30px}
.card{background:var(--card);border-radius:20px;padding:40px;box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:30px}
.bc-header{margin-bottom:24px}
.bc-header-title{font-size:28px;font-weight:700;margin-bottom:8px}
.bc-header-sub{font-size:15px;color:var(--muted);margin-bottom:0}
.bc-header-divider{border:none;border-top:2px solid var(--border);margin:20px 0 0}

/* ===== 区块头部 ===== */
.sec-header{display:flex;align-items:center;gap:16px;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.sec-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px}
.sec-icon.green{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}
.sec-icon.orange{background:linear-gradient(135deg,#fff3e0,#ffe0b2)}
.sec-icon.blue{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}
.sec-icon.purple{background:linear-gradient(135deg,#f3e5f5,#e1bee7)}
.sec-title{font-size:24px;font-weight:600}
.sec-sub{font-size:14px;color:var(--muted);margin-top:4px}

/* ===== Hero ===== */
.hero-card{text-align:center;padding:80px 50px}
.hero-title{font-size:42px;font-weight:700;margin-bottom:20px;line-height:1.4}
.hero-title em{color:var(--green);font-style:normal}
.hero-desc{font-size:16px;color:var(--txt2);max-width:600px;margin:0 auto 30px}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ===== 网格 ===== */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ===== 分类条目 ===== */
.item{background:var(--bg2);border-radius:14px;padding:20px;transition:all .3s;display:block;cursor:pointer;text-decoration:none}
.item:hover{background:var(--card);border:1px solid var(--border);transform:translateY(-3px);box-shadow:var(--shadow)}
.item-icon{font-size:24px;margin-bottom:12px}
.item-name{font-size:15px;font-weight:500;margin-bottom:6px}
.item-desc{font-size:13px;color:var(--muted)}
.sub-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.sub-tag{background:var(--card);padding:5px 12px;border-radius:20px;font-size:12px;color:var(--txt2);border:1px solid var(--border);text-decoration:none}
.sub-tag:hover{color:var(--green);border-color:var(--green)}

/* ===== 房产模块 ===== */
.house-type-row{display:flex;gap:24px;margin-bottom:30px}
.house-type-col{flex:1;background:var(--card);border-radius:16px;padding:24px;border:1px solid var(--border);box-shadow:var(--shadow)}
.house-type-col-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.house-type-col-icon{font-size:24px}
.house-type-col-title{font-size:16px;font-weight:600}
.house-type-col-more{font-size:12px;color:var(--muted);margin-left:auto;text-decoration:none}
.house-type-col-more:hover{color:var(--green)}
.house-type-list{display:flex;flex-direction:column;gap:8px}
.house-type-item{background:var(--card);border-radius:12px;overflow:hidden;transition:all .3s;display:flex;flex-direction:row;text-decoration:none;border:1px solid var(--border);box-shadow:var(--shadow);height:120px}
.house-type-item:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.1)}
.house-type-item-img{width:120px;min-width:120px;height:88px;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:8px;margin:16px}
.house-type-item-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.house-type-item-img .house-img-wrap{display:block;width:120px;height:88px;overflow:hidden}
.house-type-item:hover .house-type-item-img img{transform:scale(1.05)}
.house-type-item-icon{font-size:32px}
.house-type-item-img.green{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}
.house-type-item-img.blue{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}
.house-type-item-img.orange{background:linear-gradient(135deg,#fff3e0,#ffe0b2)}
.house-type-item-img.purple{background:linear-gradient(135deg,#f3e5f5,#e1bee7)}
.house-type-item-info{padding:16px 16px 16px 0;display:flex;flex-direction:column;gap:4px;flex:1;justify-content:center;min-width:0}
.house-type-item-name{font-size:14px;font-weight:500;line-height:1.4;color:var(--txt)}
.house-type-item-area{font-size:12px;color:var(--muted)}
.house-type-item-price{font-size:17px;font-weight:700;color:var(--orange);margin-top:4px}

/* ===== 标签 ===== */
.type-tag{padding:6px 14px;border-radius:20px;font-size:14px;color:#fff;display:inline-block}
.type-tag.green{background:var(--green)}
.type-tag.blue{background:#2196f3}
.type-tag.orange{background:#ff9800}
.type-tag.purple{background:#9c27b0}

/* ===== 房源列表�?===== */
.house-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.house-item{background:var(--card);border-radius:16px;display:flex;flex-direction:column;text-decoration:none;transition:all .3s;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)}
.house-item:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.1)}
.house-item-img{width:100%;height:220px;overflow:hidden;background:var(--bg2);position:relative;flex-shrink:0}
.house-item-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.house-item:hover .house-item-img img{transform:scale(1.05)}
.house-item-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px}
.house-item-img-placeholder.green{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}
.house-item-img-placeholder.blue{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}
.house-item-img-placeholder.orange{background:linear-gradient(135deg,#fff3e0,#ffe0b2)}
.house-item-img-placeholder.purple{background:linear-gradient(135deg,#f3e5f5,#e1bee7)}
.house-item-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:6px;flex:1}
.house-item-city{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;color:#fff;width:fit-content;flex-shrink:0}
.house-item-city.green{background:var(--green)}
.house-item-city.blue{background:#2196f3}
.house-item-city.orange{background:#ff9800}
.house-item-city.purple{background:#9c27b0}
.house-item-title{font-size:15px;font-weight:500;line-height:1.4}
.house-item-info{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:4px}
.house-item-price{font-size:20px;font-weight:700;color:var(--orange);margin-top:4px}

/* ===== 城市标签 ===== */
.city-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:30px;padding:20px;background:var(--bg2);border-radius:16px}
.city-tab{padding:8px 18px;border-radius:20px;background:var(--card);border:1px solid var(--border);font-size:14px;color:var(--txt2);cursor:pointer;transition:all .3s}
.city-tab:hover,.city-tab.active{background:var(--green);color:#fff;border-color:var(--green)}

/* ===== 房源详情�?===== */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.detail-info{background:var(--bg2);border-radius:16px;padding:30px}
.detail-info h2{font-size:24px;margin-bottom:16px;line-height:1.4}
.detail-meta{display:flex;flex-direction:column;gap:12px;font-size:15px;color:var(--txt2)}
.detail-price{font-size:32px;font-weight:700;color:var(--orange);margin-top:20px}
.detail-desc{background:var(--card);border-radius:16px;padding:30px;border:1px solid var(--border)}
.detail-desc h3{font-size:18px;margin-bottom:16px}
.detail-desc p{color:var(--txt2);line-height:2}

/* ===== 面包�?===== */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--muted);margin-bottom:30px;flex-wrap:wrap}
.breadcrumb a{color:var(--txt2);text-decoration:none}
.breadcrumb a:hover{color:var(--green)}
.breadcrumb .current{color:var(--txt)}

/* ===== 文章列表 ===== */
.article-list{display:flex;flex-direction:column;gap:16px}
.article-item{display:flex;gap:20px;padding:20px;background:var(--bg2);border-radius:14px;transition:all .3s;text-decoration:none}
.article-item:hover{background:var(--card);transform:translateY(-2px);box-shadow:var(--shadow)}
.article-thumb{width:120px;height:80px;background:var(--green);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:32px;flex-shrink:0}
.article-info{flex:1}
.article-title{font-size:16px;font-weight:500;margin-bottom:8px}
.article-meta{font-size:13px;color:var(--muted);display:flex;gap:16px;flex-wrap:wrap}
.article-tags{display:flex;gap:6px;flex-wrap:wrap}
.article-tag{background:var(--card);padding:2px 10px;border-radius:12px;font-size:11px;color:var(--txt2);border:1px solid var(--border)}

/* ===== 文章详情 ===== */
.article-header h1{font-size:28px;font-weight:700;margin-bottom:20px;line-height:1.4}
.article-header .meta{display:flex;gap:20px;font-size:14px;color:var(--muted);margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.article-content{color:var(--txt2);line-height:2;font-size:16px}
.article-content p{margin-bottom:16px}
.article-content img{border-radius:12px;margin:16px 0}
.article-content h2,.article-content h3,.article-content h4{margin-top:24px;margin-bottom:12px;color:var(--txt)}
.article-nav{display:flex;justify-content:space-between;margin-top:40px;padding-top:20px;border-top:1px solid var(--border);gap:20px}
.article-nav a{color:var(--green);font-size:14px;max-width:45%}
.article-nav a:hover{text-decoration:underline}

/* ===== 房源状态标�?===== */
.house-status{padding:3px 10px;border-radius:12px;font-size:12px;display:inline-block;margin-left:8px}
.house-status.sold{background:#ffebee;color:#c62828;border:1px solid #ef9a9a}
.house-status.rented{background:#e3f2fd;color:#1565c0;border:1px solid #90caf9}
.house-status.delisted{background:#f5f5f5;color:#757575;border:1px solid #bdbdbd}
.house-status.forced{background:#fff3e0;color:#e65100;border:1px solid #ffcc80}
.house-status.active{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}

/* ===== 会员中心 ===== */
.member-card{background:var(--card);border-radius:16px;padding:30px;border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:24px}
.member-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.member-avatar{width:60px;height:60px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff}
.member-info h3{font-size:18px;margin-bottom:4px}
.member-info p{font-size:13px;color:var(--muted)}
.member-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}
.member-stat{background:var(--bg2);padding:16px;border-radius:12px;text-align:center}
.member-stat-value{font-size:22px;font-weight:600;color:var(--green)}
.member-stat-label{font-size:12px;color:var(--muted);margin-top:4px}
.status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px}
.status-badge.verified{background:#e8f5e9;color:#2e7d32}
.status-badge.pending{background:#fff3e0;color:#e65100}
.status-badge.failed{background:#ffebee;color:#c62828}
.status-badge.unverified{background:#f5f5f5;color:#757575}

/* ===== 登录�?===== */
.login-card{max-width:420px;margin:60px auto;padding:50px 40px}
.login-title{text-align:center;font-size:28px;font-weight:600;margin-bottom:8px}
.login-sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:32px}
.login-divider{text-align:center;position:relative;margin:24px 0;color:var(--muted);font-size:13px}
.login-divider::before,.login-divider::after{content:'';position:absolute;top:50%;width:40%;height:1px;background:var(--border)}
.login-divider::before{left:0}
.login-divider::after{right:0}
.login-tabs{display:flex;gap:1px;margin-bottom:24px;border-radius:10px;overflow:hidden;border:1px solid var(--border)}
.login-tab{flex:1;text-align:center;padding:12px;cursor:pointer;background:var(--bg2);transition:all .3s;font-size:14px}
.login-tab.active{background:var(--green);color:#fff}

/* ===== 表单 ===== */
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:14px;font-weight:500;margin-bottom:8px;color:var(--txt)}
.form-group .required{color:#c62828;margin-left:2px}
.form-control{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:10px;font-size:15px;background:var(--card);color:var(--txt);transition:border .3s}
.form-control:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(107,142,107,.15)}
.form-control::placeholder{color:var(--muted)}
textarea.form-control{min-height:100px;resize:vertical}
select.form-control{cursor:pointer}
.form-hint{font-size:12px;color:var(--muted);margin-top:4px}
.form-error{font-size:12px;color:#c62828;margin-top:4px}

/* ===== 房源表格 ===== */
.admin-table{width:100%;border-collapse:collapse;font-size:14px}
.admin-table th{padding:12px 16px;text-align:left;background:var(--bg2);border-bottom:2px solid var(--border);font-weight:600}
.admin-table td{padding:12px 16px;border-bottom:1px solid var(--border)}
.admin-table tr:hover td{background:var(--bg2)}
.admin-table .actions{display:flex;gap:6px;flex-wrap:wrap}
.admin-table .actions .btn{padding:4px 12px;font-size:12px;border-radius:6px}

/* ===== 搜索 ===== */
.search-box{display:flex;gap:12px;margin-bottom:24px}
.search-box input{flex:1}

/* ===== 公告通知 ===== */
.alert{padding:16px 20px;border-radius:12px;margin-bottom:20px;font-size:14px;display:flex;align-items:center;gap:12px}
.alert-info{background:#e3f2fd;color:#1565c0;border:1px solid #90caf9}
.alert-success{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}
.alert-warning{background:#fff3e0;color:#e65100;border:1px solid #ffcc80}
.alert-error{background:#ffebee;color:#c62828;border:1px solid #ef9a9a}

/* ===== 侧栏模块 ===== */
.sidebar{margin-bottom:30px}
.sidebar .widget{margin-bottom:24px}
.sidebar .widget h4{font-size:16px;font-weight:600;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.sidebar .widget ul{list-style:none}
.sidebar .widget li{padding:8px 0;border-bottom:1px solid var(--border);font-size:14px}
.sidebar .widget li a{color:var(--txt2);text-decoration:none}
.sidebar .widget li a:hover{color:var(--green)}
.sidebar .widget li:last-child{border-bottom:none}

/* ===== 搜索面板 ===== */
.search-form{display:flex;gap:8px}
.search-form input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px}
.search-form button{padding:10px 18px;border:none;background:var(--green);color:#fff;border-radius:8px;cursor:pointer}

/* ===== 评论�?===== */
.comments{margin-top:40px;padding-top:30px;border-top:1px solid var(--border)}
.comments h3{font-size:20px;margin-bottom:20px}
.comment-item{padding:20px;background:var(--bg2);border-radius:12px;margin-bottom:16px}
.comment-meta{font-size:13px;color:var(--muted);margin-bottom:8px}
.comment-content{max-height:500px;overflow-y:auto;font-size:14px;color:var(--txt2);line-height:1.8;word-break:break-word;overflow-wrap:break-word}
.comment-content pre{background:#1e1e1e;color:#d4d4d4;border-radius:8px;padding:16px;overflow-x:auto;margin:12px 0;word-break:normal!important;overflow-wrap:normal!important;white-space:pre;font-size:13px;line-height:1.6;border:1px solid #333}
.comment-content code{font-family:'Consolas','Monaco','Courier New',monospace;font-size:13px}
.comment-content pre code{background:none!important;padding:0!important;color:inherit;font-size:inherit;border:none}
.comment-content p code{background:#f4f4f4;color:#c7254e;padding:2px 6px;border-radius:3px;font-size:90%}

/* ===== 已售印章 Overlay ===== */
.house-img-wrap{position:relative;display:inline-block;width:100%;height:100%;overflow:hidden}
.house-sold-stamp{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:2}
.house-sold-stamp img{width:auto;height:auto;max-width:70%;max-height:70%;object-fit:contain;opacity:.88}
/* 分类页列表印章覆盖 */
.house-list-img-wrap{position:relative;display:inline-block;width:100%;height:100%;border-radius:10px;overflow:hidden}
.house-list-img-wrap .house-sold-stamp img{max-width:60%;max-height:60%}
/* 分类页列表图片中的印章适当缩小 */
.house-list-img .house-img-wrap{display:block;width:100%;height:100%}
.house-list-img .house-sold-stamp img{max-width:55%;max-height:55%}

/* ===== 分页 ===== */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:30px;flex-wrap:wrap}
.pagination span,.pagination a{padding:8px 16px;border-radius:8px;font-size:14px;text-decoration:none;background:var(--card);border:1px solid var(--border);color:var(--txt2)}
.pagination .current{background:var(--green);color:#fff;border-color:var(--green)}
.pagination a:hover{background:var(--bg2)}
.pagination .now-page{background:var(--green);color:#fff;border-color:var(--green)}

/* ===== 页脚 ===== */
.footer{background:var(--card);border-top:1px solid var(--border);padding:40px 30px;text-align:center}
.footer-logo{font-size:20px;font-weight:600;margin-bottom:12px}
.footer-logo span{color:var(--green)}
.footer-desc{font-size:14px;color:var(--muted);margin-bottom:20px}
.footer-links{display:flex;justify-content:center;gap:30px;flex-wrap:wrap}
.footer-link{color:var(--txt2);font-size:14px;text-decoration:none}
.footer-link:hover{color:var(--green)}
.footer-copy{font-size:12px;color:var(--muted);margin-top:16px}

/* ===== 空状�?===== */
.no-content{text-align:center;padding:60px 0;color:var(--muted);font-size:16px}

/* ===== 分类页双栏布局 ===== */
.category-layout{display:flex;gap:30px;align-items:flex-start}
.category-main{flex:1;min-width:0}
.category-main .card{margin-bottom:0}
.category-sidebar{width:300px;flex-shrink:0;position:sticky;top:90px;align-self:flex-start}
.category-sidebar .card{padding:24px;margin-bottom:0}
.sidebar-widget-title{font-size:16px;font-weight:600;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);color:var(--txt);display:flex;align-items:center;gap:8px}
.category-sidebar .ad-slot{background:var(--bg2);border-radius:12px;border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;transition:all .3s;width:100%}
.category-sidebar .ad-slot:hover{border-color:var(--green2);background:var(--card)}
.ad-slot-300{height:250px}
.ad-slot-wide{height:600px}
.ad-slot-banner{height:100px}
.ad-label{font-size:14px;color:var(--muted);user-select:none}
.house-list{display:flex;flex-direction:column;gap:12px}
.house-list-item{display:flex;gap:16px;padding:16px;background:var(--bg2);border-radius:14px;transition:all .3s;text-decoration:none;align-items:center}
.house-list-item:hover{background:var(--card);transform:translateY(-2px);box-shadow:var(--shadow)}
.house-list-img{width:120px;height:90px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:28px}
.house-list-img img{width:100%;height:100%;object-fit:cover}
.house-list-img-placeholder{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}
.house-list-info{flex:1;min-width:0;padding-right:4px}
.house-list-info strong{font-size:15px;color:var(--txt);display:block;margin-bottom:4px}
.house-list-detail{list-style:none;padding:0;margin:4px 0 0;font-size:13px;color:var(--muted)}
.house-list-meta{font-size:13px;color:var(--muted);margin-bottom:4px}
.house-list-price{font-size:18px;font-weight:700;color:#c62828}

/* ===== 房源表格 ===== */
.house-table-wrap{overflow-x:auto}
.house-table{width:100%;border-collapse:collapse;font-size:14px}
.house-table thead th{padding:12px 16px;text-align:left;background:var(--bg2);border-bottom:2px solid var(--border);font-weight:600;color:var(--txt);white-space:nowrap}
.house-table tbody td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--txt2)}
.house-table tbody tr:hover td{background:var(--bg2)}
.house-table-idx{text-align:center;color:var(--muted)!important;font-size:13px}
.house-table-name a{color:var(--txt);font-weight:500;text-decoration:none}
.house-table-name a:hover{color:var(--green)}
.house-table-info{font-size:13px;color:var(--muted)}
.house-table-price{font-weight:600;color:var(--orange);white-space:nowrap}

/* ===== 文章流内嵌广�?===== */
.infeed-ad{padding:4px 0}
.infeed-ad-inner{background:var(--bg2);border-radius:12px;border:2px dashed var(--border);height:90px;display:flex;align-items:center;justify-content:center;transition:all .3s}
.infeed-ad-inner:hover{border-color:var(--green2);background:var(--card)}
.infeed-ad .ad-label{font-size:13px}

/* 文章列表�?- 分类�?*/
.article-item{height:138px;display:flex;gap:20px;padding:20px;background:var(--bg2);border-radius:14px;transition:all .3s;text-decoration:none}
.article-item:hover{background:var(--card);transform:translateY(-2px);box-shadow:var(--shadow)}

/* ===== 响应�?===== */
@media(max-width:768px){
.nav-inner{padding:0 16px}
.nav-menu{display:none}
.nav-menu.open{display:flex;position:absolute;top:70px;left:0;right:0;background:var(--card);flex-direction:column;padding:16px;border-bottom:1px solid var(--border);box-shadow:var(--shadow)}
.hamburger{display:block!important}
.hero-title{font-size:28px}
.hero-card{padding:40px 24px}
.house-type-row,.house-grid{grid-template-columns:1fr}
.house-type-row{flex-direction:column}
.detail-grid{grid-template-columns:1fr}
.grid2{grid-template-columns:1fr}
.wrap{padding:20px 16px}
.card{padding:24px 20px}
.article-thumb{width:80px;height:60px;font-size:24px}
.category-layout{flex-direction:column}
.category-sidebar{width:100%;position:static}
.ad-slot-300,.ad-slot-wide,.ad-slot-banner{height:160px}
.infeed-ad-inner{height:70px}
}

.hamburger{display:none;background:none;border:none;font-size:24px;cursor:pointer;padding:8px;color:var(--txt2)}

/* ===== 房源发布�?===== */
.publish-wrap{max-width:900px;margin:0 auto}
.publish-card{background:var(--card);border-radius:20px;padding:36px 40px;box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:24px;transition:all .3s}
.publish-card:hover{box-shadow:0 6px 30px rgba(0,0,0,.08)}
.publish-card-header{display:flex;align-items:center;gap:14px;margin-bottom:28px;padding-bottom:18px;border-bottom:2px solid var(--bg2)}
.publish-card-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.publish-card-icon.green{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}
.publish-card-icon.orange{background:linear-gradient(135deg,#fff3e0,#ffe0b2)}
.publish-card-icon.blue{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}
.publish-card-icon.purple{background:linear-gradient(135deg,#f3e5f5,#e1bee7)}
.publish-card-icon.red{background:linear-gradient(135deg,#ffebee,#ffcdd2)}
.publish-card-title{font-size:18px;font-weight:600;color:var(--txt)}
.publish-card-desc{font-size:13px;color:var(--muted);margin-top:2px}

/* 发布表单�?*/
.publish-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.publish-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.publish-row-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px}
.publish-group{margin-bottom:22px}
.publish-group:last-child{margin-bottom:0}
.publish-label{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--txt);margin-bottom:8px}
.publish-label .required{color:#c62828}
.publish-label .hint{font-size:12px;color:var(--muted);font-weight:400;margin-left:auto}
.publish-input,.publish-select,.publish-textarea{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:12px;font-size:15px;background:var(--card);color:var(--txt);transition:all .25s;font-family:inherit}
.publish-input:focus,.publish-select:focus,.publish-textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(107,142,107,.12)}
.publish-input::placeholder,.publish-textarea::placeholder{color:var(--muted)}
.publish-input.error,.publish-select.error{border-color:#c62828;box-shadow:0 0 0 4px rgba(198,40,40,.1)}
.publish-textarea{min-height:120px;resize:vertical;line-height:1.7}
.publish-textarea.counted{min-height:100px}
.publish-textarea + .char-count{text-align:right;font-size:12px;color:var(--muted);margin-top:4px;padding-right:4px}
.publish-textarea + .char-count.warn{color:#e65100}
.publish-textarea + .char-count.limit{color:#c62828}
.publish-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%239A9A9A'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.publish-error{font-size:12px;color:#c62828;margin-top:4px;display:none;align-items:center;gap:4px}
.publish-error.show{display:flex}
.publish-hint{font-size:12px;color:var(--muted);margin-top:4px;display:flex;align-items:center;gap:4px}

/* 类型选择卡片 */
.type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.type-card{position:relative;cursor:pointer}
.type-card input{position:absolute;opacity:0;pointer-events:none}
.type-card-inner{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 12px;border:2px solid var(--border);border-radius:14px;background:var(--card);transition:all .25s;text-align:center}
.type-card-inner:hover{border-color:var(--green2);background:var(--bg2)}
.type-card input:checked + .type-card-inner{border-color:var(--green);background:linear-gradient(135deg,#e8f5e9,#f1f8e9);box-shadow:0 0 0 3px rgba(107,142,107,.15)}
.type-card-icon{font-size:32px;line-height:1}
.type-card-name{font-size:14px;font-weight:500;color:var(--txt)}
.type-card-price{font-size:11px;color:var(--muted)}

/* 价格输入�?*/
.price-input-wrap{display:flex;align-items:center;gap:0}
.price-input-wrap .publish-input{border-radius:12px 0 0 12px;border-right:none}
.price-input-wrap .price-unit{padding:12px 18px;background:var(--bg2);border:2px solid var(--border);border-left:none;border-radius:0 12px 12px 0;font-size:14px;color:var(--txt2);white-space:nowrap}

/* 图片上传 */
.image-upload-area{position:relative;border:2px dashed var(--border);border-radius:16px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s;background:var(--bg2)}
.image-upload-area:hover,.image-upload-area.dragover{border-color:var(--green);background:linear-gradient(135deg,#e8f5e9,#f1f8e9)}
.image-upload-area.has-error{border-color:#c62828;background:#ffebee}
.image-upload-icon{font-size:48px;margin-bottom:12px;opacity:.6}
.image-upload-text{font-size:15px;color:var(--txt2);margin-bottom:4px}
.image-upload-hint{font-size:12px;color:var(--muted)}
.image-upload-input{position:absolute;inset:0;opacity:0;cursor:pointer}
.image-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin-top:16px}
.image-preview-item{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:1;background:var(--bg2);border:1px solid var(--border)}
.image-preview-item img{width:100%;height:100%;object-fit:cover}
.image-preview-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;border:none;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.image-preview-remove:hover{background:rgba(198,40,40,.8);transform:scale(1.1)}
.image-preview-item .status{position:absolute;bottom:0;left:0;right:0;padding:4px;font-size:11px;text-align:center;background:rgba(0,0,0,.5);color:#fff}
.image-preview-item .status.done{background:var(--green)}
.image-preview-item .status.error{background:#c62828}

/* 联系方式切换 */
.contact-toggle{display:flex;gap:1px;border:2px solid var(--border);border-radius:12px;overflow:hidden;width:fit-content}
.contact-toggle-btn{padding:10px 22px;font-size:14px;cursor:pointer;background:var(--card);color:var(--txt2);transition:all .25s;border:none;font-family:inherit}
.contact-toggle-btn.active{background:var(--green);color:#fff}
.contact-toggle-btn:not(.active):hover{background:var(--bg2)}

/* 预览�?*/
.publish-preview{background:var(--bg2);border-radius:16px;padding:24px;margin-top:24px}
.publish-preview-title{font-size:14px;font-weight:500;color:var(--txt2);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.preview-card{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card)}
.preview-card-img{height:140px;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);display:flex;align-items:center;justify-content:center;font-size:40px;color:var(--green2)}
.preview-card-body{padding:16px}
.preview-card-body .tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;color:#fff;margin-bottom:8px}
.preview-card-body .tag.green{background:var(--green)}
.preview-card-body .tag.blue{background:#2196f3}
.preview-card-body .tag.orange{background:#ff9800}
.preview-card-body .tag.purple{background:#9c27b0}
.preview-card-body h4{font-size:15px;font-weight:600;margin-bottom:6px;color:var(--txt)}
.preview-card-body .meta{font-size:12px;color:var(--muted);display:flex;gap:12px;margin-bottom:8px}
.preview-card-body .price{font-size:20px;font-weight:700;color:var(--orange)}
.preview-empty{padding:40px;text-align:center;color:var(--muted);font-size:14px}

/* 发布底部操作�?*/
.publish-actions{display:flex;gap:16px;justify-content:flex-end;align-items:center;padding-top:24px;border-top:1px solid var(--border);margin-top:8px}
.publish-actions .btn{padding:16px 40px;font-size:16px}
.publish-agree{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--txt2);margin-right:auto}
.publish-agree input[type=checkbox]{width:18px;height:18px;accent-color:var(--green);cursor:pointer}
.publish-agree a{color:var(--green);text-decoration:underline}

/* 成功状�?*/
.publish-success{text-align:center;padding:60px 40px}
.publish-success-icon{font-size:72px;margin-bottom:20px}
.publish-success h2{font-size:28px;font-weight:600;margin-bottom:12px}
.publish-success p{font-size:15px;color:var(--txt2);margin-bottom:30px}
.publish-success .btn{margin:0 8px}

@media(max-width:768px){
.house-grid{grid-template-columns:1fr;gap:16px}
.house-item-img{height:200px}
.publish-card{padding:24px 20px}
.publish-row,.publish-row-3,.publish-row-4{grid-template-columns:1fr}
.type-grid{grid-template-columns:repeat(2,1fr)}
.publish-actions{flex-direction:column;align-items:stretch}
.publish-agree{margin-right:0;margin-bottom:12px}
.image-upload-area{padding:24px 16px}
.image-preview-grid{grid-template-columns:repeat(3,1fr)}
.price-input-wrap .price-unit{padding:12px 14px;font-size:13px}
}

/* ===== 文章页双栏布局 ===== */
.article-layout{display:flex;gap:30px;align-items:flex-start}
.article-main{flex:1;min-width:0}
.article-main .card{margin-bottom:0}
.article-sidebar{width:300px;flex-shrink:0;position:sticky;top:90px;align-self:flex-start}
.article-sidebar .card{padding:24px;margin-bottom:0}
.article-sidebar .ad-slot{background:var(--bg2);border-radius:12px;border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;transition:all .3s;width:100%}
.article-sidebar .ad-slot:hover{border-color:var(--green2);background:var(--card)}

/* ===== 评论�?===== */
.comment-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.comment-header h3{font-size:20px;font-weight:600}
.comment-count{font-size:14px;color:var(--muted);margin-left:auto}
.comment-list{margin-bottom:30px}
.comment-loading,.comment-empty{text-align:center;padding:40px 0;color:var(--muted);font-size:15px}
.comment-item{display:flex;gap:14px;padding:20px 0;border-bottom:1px solid var(--border)}
.comment-item:last-child{border-bottom:none}
.comment-item.comment-reply{margin-left:50px;padding:14px 0 14px 18px;border-left:3px solid var(--green2);border-bottom:1px solid var(--border);background:var(--bg2);border-radius:0 10px 10px 0;margin-bottom:2px;padding-right:14px}
.comment-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--bg2)}
.comment-avatar img{width:100%;height:100%;object-fit:cover}
.comment-body{flex:1;min-width:0}
.comment-meta{display:flex;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap;font-size:13px}
.comment-author{font-weight:600;color:var(--txt);font-size:14px}
.comment-reply-to{color:var(--green);font-size:12px;background:var(--bg2);padding:2px 10px;border-radius:10px}
.comment-time{color:var(--muted);font-size:12px;margin-left:auto}
.comment-content{max-height:500px;overflow-y:auto;font-size:14px;color:var(--txt2);line-height:1.8;word-break:break-word;overflow-wrap:break-word}
.comment-content pre{background:#1e1e1e;color:#d4d4d4;border-radius:8px;padding:16px;overflow-x:auto;margin:12px 0;word-break:normal!important;overflow-wrap:normal!important;white-space:pre;font-size:13px;line-height:1.6;border:1px solid #333}
.comment-content code{font-family:'Consolas','Monaco','Courier New',monospace;font-size:13px}
.comment-content pre code{background:none!important;padding:0!important;color:inherit;font-size:inherit;border:none}
.comment-content p code{background:#f4f4f4;color:#c7254e;padding:2px 6px;border-radius:3px;font-size:90%}
.comment-content p{margin-bottom:10px}
.comment-content p:last-child{margin-bottom:0}
.comment-content img{max-width:100%;border-radius:8px;margin:6px 0;display:block}
.comment-content pre{background:#f6f8fa;border-radius:10px;padding:14px 16px;overflow-x:auto;font-size:13px;line-height:1.6;margin:10px 0;border:1px solid var(--border)}
.comment-content pre code{background:none;padding:0;font-size:13px;border:none}
.comment-content code{background:#f0f0f0;padding:2px 6px;border-radius:4px;font-size:13px;font-family:"SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace}
.comment-content blockquote{border-left:4px solid var(--green2);padding:10px 16px;margin:10px 0;background:var(--bg2);border-radius:0 8px 8px 0;color:var(--txt2)}
.comment-content ul,.comment-content ol{padding-left:24px;margin:8px 0}
.comment-content li{margin-bottom:4px}
.comment-reply-btn{font-size:12px;color:var(--green);background:none;border:none;cursor:pointer;padding:4px 0;margin-top:6px;transition:color .2s;font-family:inherit}
.comment-reply-btn:hover{color:var(--orange)}
.comment-children{margin-left:0}

/* ===== 评论表单 ===== */
.comment-form-wrap{padding-top:4px}
.comment-form-title{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.comment-form-title span:first-child{font-size:16px;font-weight:600}
.comment-form-hint{font-size:12px;color:var(--muted)}
.comment-form-row{display:flex;gap:14px;margin-bottom:14px}
.reply-target{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--bg2);border-radius:10px;margin-bottom:14px;font-size:14px;color:var(--txt2);border:1px solid var(--border)}
.reply-cancel{font-size:12px;color:var(--muted);background:none;border:none;cursor:pointer;margin-left:auto;padding:4px 10px;border-radius:6px;transition:all .2s;font-family:inherit}
.reply-cancel:hover{color:#c62828;background:rgba(198,40,40,.08)}

/* ===== 编辑�?===== */
.editor-toolbar{display:flex;align-items:center;gap:4px;padding:8px 12px;background:var(--bg2);border:1px solid var(--border);border-bottom:none;border-radius:12px 12px 0 0;flex-wrap:wrap}
.editor-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:var(--card);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:14px;color:var(--txt);transition:all .2s;font-family:inherit;padding:0}
.editor-btn:hover{background:var(--bg2);border-color:var(--green2);color:var(--green)}
.editor-divider{width:1px;height:24px;background:var(--border);margin:0 4px}
.editor-wrap{position:relative}
.editor{min-height:160px;max-height:400px;padding:14px 16px;border:1px solid var(--border);border-radius:0 0 12px 12px;font-size:15px;line-height:1.8;color:var(--txt);background:var(--card);overflow-y:auto;outline:none;transition:border-color .2s;font-family:inherit}
.editor:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(107,142,107,.1)}
.editor img{max-width:100%;border-radius:8px;margin:8px 0;display:block}
.editor pre{background:#f6f8fa;border-radius:8px;padding:12px 14px;overflow-x:auto;font-size:13px;line-height:1.6;margin:8px 0;border:1px solid var(--border)}
.editor pre code{background:none;padding:0;font-size:13px;border:none}
.editor code{background:#f0f0f0;padding:2px 6px;border-radius:4px;font-size:13px}
.editor blockquote{border-left:4px solid var(--green2);padding:8px 14px;margin:8px 0;background:var(--bg2);border-radius:0 8px 8px 0;color:var(--txt2)}
.editor ul,.editor ol{padding-left:24px;margin:8px 0}
.editor:empty:before{content:attr(data-placeholder);color:var(--muted);pointer-events:none}
.comment-form-actions{display:flex;justify-content:flex-end;margin-top:14px;gap:10px}

/* ===== 代码插入弹窗 ===== */
.code-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.code-modal-content{background:var(--card);border-radius:16px;padding:28px;width:100%;max-width:560px;box-shadow:0 20px 60px rgba(0,0,0,.2);border:1px solid var(--border);max-height:80vh;overflow-y:auto}
.code-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;font-size:18px;font-weight:600}
.code-modal-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--txt2);transition:all .2s}
.code-modal-close:hover{background:rgba(198,40,40,.1);color:#c62828}

/* ===== 上传进度 ===== */
.upload-progress{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg2);border-radius:10px;margin-top:10px;border:1px solid var(--border)}
.upload-progress-bar{height:6px;background:var(--green);border-radius:3px;width:0%;transition:width .3s;flex:1;max-width:200px}
.upload-progress-text{font-size:12px;color:var(--muted);min-width:40px}

/* ===== 文章页响应式 ===== */
@media(max-width:768px){
.article-layout{flex-direction:column}
.article-sidebar{width:100%;position:static}
.article-sidebar .ad-slot{height:160px}
.comment-form-row{flex-direction:column}
.comment-item.comment-reply{margin-left:20px}
.comment-meta{font-size:12px}
.code-modal-content{padding:20px;max-width:100%;border-radius:12px;margin:10px}
.editor{min-height:130px}
}

/* ===== 文章内容溢出修复 ===== */
.article-main .card{overflow:hidden;min-width:0}
.article-content{word-break:break-word;overflow-wrap:break-word}
.article-content pre{overflow-x:auto;white-space:pre-wrap;word-break:break-word}
.article-content table{display:block;overflow-x:auto;max-width:100%}
.article-content img{max-width:100%;height:auto}
.article-content iframe{max-width:100%}

/* ===== 文章内容内边�?===== */
.article-content{padding:0 12px}
.article-content p{padding:0 4px}
.article-content li{padding:2px 0}

/* ===== 文章布局修正 ===== */
.article-main .card{overflow:visible}

/* ===== 强制覆盖编辑�?nowrap 问题 ===== */
.article-content *{text-wrap-mode:wrap!important;white-space:normal!important}
.article-content pre{white-space:pre-wrap!important;text-wrap-mode:wrap!important}
