/*
Theme Name: TNRealEstate Directory
Theme URI: https://tnrealestate.in
Author: BRUsoft
Author URI: https://brusoft.in
Description: Custom real estate directory theme for tnrealestate.in — Property listings (sale/rent/lease) + Real Estate Services directory across 38 Tamil Nadu districts. Dual CPT system with frontend submission, pricing tiers, schema markup, WhatsApp integration.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: Proprietary
Text Domain: tnre
*/

/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
--tn-primary:#0097B2;--tn-primary-dark:#007A91;--tn-primary-light:#E6F7FA;--tn-primary-glow:rgba(0,151,178,.12);
--tn-accent:#FF6B35;--tn-accent-hover:#E55A28;--tn-accent-light:#FFF0EA;
--tn-wa:#25D366;--tn-wa-hover:#1EBD5A;
--tn-dark:#0F1D2A;--tn-dark-sec:#162535;--tn-dark-card:#1A2D3E;
--tn-text:#1C2E3D;--tn-text-sec:#5A7184;--tn-text-light:#8A9DB0;
--tn-bg:#F5F8FA;--tn-white:#FFFFFF;--tn-border:#DDE6ED;
--tn-res:#059669;--tn-res-light:#ECFDF5;
--tn-com:#2563EB;--tn-com-light:#EFF6FF;
--tn-land:#B45309;--tn-land-light:#FFFBEB;
--tn-shadow:0 2px 12px rgba(15,29,42,.08);
--tn-shadow-lg:0 8px 30px rgba(15,29,42,.12);
--tn-radius:10px;--tn-radius-lg:14px;
--tn-font:'Source Sans 3','Segoe UI',system-ui,sans-serif;
--tn-font-head:'Sora','Source Sans 3',sans-serif;
--tn-max-w:1200px;
}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--tn-font);color:var(--tn-text);background:var(--tn-white);-webkit-font-smoothing:antialiased;line-height:1.6;font-size:15px}
h1,h2,h3,h4,h5{font-family:var(--tn-font-head);letter-spacing:-.02em;line-height:1.2}
a{text-decoration:none;color:inherit;transition:.2s}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--tn-max-w);margin:0 auto;padding:0 24px}

/* === ANIMATIONS === */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.4)}70%{box-shadow:0 0 0 14px rgba(37,211,102,0)}}

/* === TOP BAR === */
.tn-topbar{background:var(--tn-dark);color:rgba(255,255,255,.75);font-size:12.5px;padding:7px 0}
.tn-topbar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px}
.tn-topbar a{color:rgba(255,255,255,.9);font-weight:600}
.tn-topbar a:hover{color:var(--tn-accent)}
.tn-topbar-right{display:flex;gap:16px}

/* === HEADER === */
.tn-header{background:var(--tn-white);padding:12px 0;position:sticky;top:0;z-index:100;border-bottom:1px solid var(--tn-border);box-shadow:0 1px 4px rgba(0,0,0,.04)}
.tn-header .container{display:flex;align-items:center;justify-content:space-between}
.tn-logo{display:flex;align-items:center;gap:10px}
.tn-logo-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--tn-primary),var(--tn-primary-dark));border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;font-family:var(--tn-font-head);line-height:1;flex-shrink:0}
.tn-logo-text strong{font-size:16px;font-weight:800;color:var(--tn-dark);display:block;font-family:var(--tn-font-head)}
.tn-logo-text span{font-size:10px;color:var(--tn-primary);font-weight:700;letter-spacing:.6px;text-transform:uppercase}
.tn-nav{display:flex;gap:3px;align-items:center}
.tn-nav a{padding:8px 13px;font-size:13.5px;font-weight:500;color:var(--tn-text-sec);border-radius:6px;transition:.2s}
.tn-nav a:hover,.tn-nav a.active{color:var(--tn-primary);background:var(--tn-primary-glow)}
.tn-nav-cta{background:var(--tn-accent)!important;color:#fff!important;font-weight:700!important;padding:9px 16px!important;border-radius:8px!important;font-size:13px!important}
.tn-nav-cta:hover{background:var(--tn-accent-hover)!important;transform:translateY(-1px)}
.tn-nav-cta2{background:var(--tn-primary)!important;color:#fff!important;font-weight:700!important;padding:9px 16px!important;border-radius:8px!important;margin-left:4px!important;font-size:13px!important}
.tn-nav-cta2:hover{background:var(--tn-primary-dark)!important}
.tn-mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--tn-dark);font-size:24px}

/* === BUTTONS === */
.tn-btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;border:none;transition:all .25s;font-family:var(--tn-font)}
.tn-btn-accent{background:var(--tn-accent);color:#fff}
.tn-btn-accent:hover{background:var(--tn-accent-hover);transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,107,53,.25)}
.tn-btn-primary{background:var(--tn-primary);color:#fff}
.tn-btn-primary:hover{background:var(--tn-primary-dark);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,151,178,.25)}
.tn-btn-wa{background:var(--tn-wa);color:#fff}
.tn-btn-wa:hover{background:var(--tn-wa-hover);transform:translateY(-2px)}
.tn-btn-outline{background:transparent;color:var(--tn-primary);border:1.5px solid var(--tn-primary)}
.tn-btn-outline:hover{background:var(--tn-primary);color:#fff}
.tn-btn-white{background:#fff;color:var(--tn-primary);font-weight:700}
.tn-btn-white:hover{transform:translateY(-2px);box-shadow:var(--tn-shadow-lg)}
.tn-btn-dark-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.tn-btn-dark-outline:hover{border-color:#fff;background:rgba(255,255,255,.08)}

/* === HERO === */
.tn-hero{background:linear-gradient(165deg,var(--tn-dark) 0%,var(--tn-dark-sec) 50%,var(--tn-primary-dark) 100%);color:#fff;padding:60px 0 50px;position:relative;overflow:hidden;text-align:center}
.tn-hero::before{content:'';position:absolute;top:-80%;right:-15%;width:600px;height:600px;background:radial-gradient(circle,rgba(0,151,178,.15) 0%,transparent 70%);border-radius:50%}
.tn-hero .container{position:relative;z-index:1}
.tn-hero-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);padding:6px 16px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;margin-bottom:16px}
.tn-hero h1{font-size:2.6rem;font-weight:800;margin-bottom:12px;letter-spacing:-.5px}
.tn-hero h1 em{font-style:normal;color:var(--tn-accent)}
.tn-hero-desc{font-size:16px;color:rgba(255,255,255,.65);max-width:600px;margin:0 auto 28px}
.tn-hero-stats{display:flex;justify-content:center;gap:40px;margin-top:28px;flex-wrap:wrap}
.tn-hero-stat strong{display:block;font-size:1.6rem;font-weight:800;color:var(--tn-accent);font-family:var(--tn-font-head)}
.tn-hero-stat span{font-size:12px;color:rgba(255,255,255,.5)}

/* === SEARCH BOX === */
.tn-search-box{background:var(--tn-white);border-radius:16px;padding:24px 28px;box-shadow:0 12px 40px rgba(15,29,42,.15);max-width:860px;margin:-40px auto 0;position:relative;z-index:10}
.tn-search-tabs{display:flex;gap:4px;margin-bottom:16px;flex-wrap:wrap}
.tn-search-tab{padding:9px 18px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;border:1.5px solid var(--tn-border);background:var(--tn-white);color:var(--tn-text-sec);transition:.2s;font-family:var(--tn-font)}
.tn-search-tab:hover{border-color:var(--tn-primary);color:var(--tn-primary)}
.tn-search-tab.active{background:var(--tn-primary);color:#fff;border-color:var(--tn-primary)}
.tn-search-filters{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr auto;gap:10px;align-items:end}
.tn-search-field label{display:block;font-size:11px;font-weight:700;color:var(--tn-text-light);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.tn-search-field select,.tn-search-field input{width:100%;padding:11px 14px;border:1.5px solid var(--tn-border);border-radius:8px;font-size:14px;font-family:var(--tn-font);color:var(--tn-text);background:var(--tn-bg)}
.tn-search-field select:focus,.tn-search-field input:focus{border-color:var(--tn-primary);outline:none;box-shadow:0 0 0 3px rgba(0,151,178,.1)}
.tn-search-btn{padding:11px 28px;background:var(--tn-accent);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:.2s;font-family:var(--tn-font);white-space:nowrap}
.tn-search-btn:hover{background:var(--tn-accent-hover)}

/* === SECTIONS === */
.tn-section{padding:60px 0}
.tn-section-alt{background:var(--tn-bg)}
.tn-section-dark{background:var(--tn-dark);color:#fff}
.tn-section-title{text-align:center;margin-bottom:42px}
.tn-section-title h2{font-size:1.8rem;font-weight:800;color:var(--tn-dark);margin-bottom:6px}
.tn-section-title h2 span{color:var(--tn-primary)}
.tn-section-title p{font-size:14px;color:var(--tn-text-sec);max-width:520px;margin:0 auto}
.tn-section-dark .tn-section-title h2{color:#fff}
.tn-section-dark .tn-section-title p{color:rgba(255,255,255,.5)}

/* === PROPERTY TYPE CARDS === */
.tn-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tn-type-card{background:var(--tn-white);border:1.5px solid var(--tn-border);border-radius:12px;padding:24px 18px;text-align:center;transition:all .3s;cursor:pointer;position:relative}
.tn-type-card:hover{border-color:var(--tn-primary);box-shadow:var(--tn-shadow-lg);transform:translateY(-4px)}
.tn-type-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:26px}
.tn-type-icon.res{background:var(--tn-res-light);border:1px solid rgba(5,150,105,.15)}
.tn-type-icon.com{background:var(--tn-com-light);border:1px solid rgba(37,99,235,.15)}
.tn-type-icon.land{background:var(--tn-land-light);border:1px solid rgba(180,83,9,.15)}
.tn-type-card h4{font-size:14px;font-weight:700;color:var(--tn-dark);margin-bottom:3px}
.tn-type-card p{font-size:11.5px;color:var(--tn-text-light)}
.tn-type-badge{position:absolute;top:10px;right:10px;font-size:9px;font-weight:700;padding:2px 8px;border-radius:4px;letter-spacing:.5px;text-transform:uppercase}
.tn-type-badge.res{background:var(--tn-res-light);color:var(--tn-res)}
.tn-type-badge.com{background:var(--tn-com-light);color:var(--tn-com)}
.tn-type-badge.land{background:var(--tn-land-light);color:var(--tn-land)}

/* === PROPERTY CARDS === */
.tn-prop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tn-prop-card{background:var(--tn-white);border:1.5px solid var(--tn-border);border-radius:12px;overflow:hidden;transition:all .3s}
.tn-prop-card:hover{border-color:var(--tn-primary);box-shadow:var(--tn-shadow-lg);transform:translateY(-4px)}
.tn-prop-img{height:200px;background:var(--tn-bg);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.tn-prop-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.tn-prop-card:hover .tn-prop-img img{transform:scale(1.05)}
.tn-prop-type-tag{position:absolute;top:12px;left:12px;padding:4px 10px;border-radius:5px;font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}
.tn-prop-type-tag.sale{background:#EF4444;color:#fff}
.tn-prop-type-tag.rent{background:var(--tn-com);color:#fff}
.tn-prop-type-tag.lease{background:var(--tn-land);color:#fff}
.tn-prop-premium-tag{position:absolute;top:12px;right:12px;background:linear-gradient(135deg,var(--tn-accent),#FF8C42);color:#fff;font-size:9px;font-weight:700;padding:3px 8px;border-radius:4px}
.tn-prop-photos{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.6);color:#fff;font-size:11px;padding:3px 8px;border-radius:4px}
.tn-prop-info{padding:18px}
.tn-prop-price{font-size:1.15rem;font-weight:800;color:var(--tn-primary);font-family:var(--tn-font-head);margin-bottom:4px}
.tn-prop-price small{font-size:12px;font-weight:500;color:var(--tn-text-light);margin-left:2px}
.tn-prop-info h4{font-size:14px;font-weight:700;color:var(--tn-dark);margin-bottom:4px;line-height:1.3}
.tn-prop-loc{font-size:12px;color:var(--tn-text-sec);display:flex;align-items:center;gap:4px;margin-bottom:10px}
.tn-prop-specs{display:flex;gap:12px;padding-top:10px;border-top:1px solid var(--tn-border);flex-wrap:wrap}
.tn-prop-spec{font-size:11.5px;color:var(--tn-text-sec);display:flex;align-items:center;gap:4px}
.tn-prop-spec strong{color:var(--tn-dark);font-weight:700}
.tn-prop-btns{display:flex;gap:6px;margin-top:12px}
.tn-prop-btn{flex:1;padding:9px;border-radius:6px;font-size:12px;font-weight:700;text-align:center;cursor:pointer;border:none;transition:.2s;font-family:var(--tn-font)}
.tn-prop-btn-wa{background:var(--tn-wa);color:#fff}
.tn-prop-btn-wa:hover{background:var(--tn-wa-hover)}
.tn-prop-btn-call{background:var(--tn-primary);color:#fff}
.tn-prop-btn-call:hover{background:var(--tn-primary-dark)}
.tn-prop-btn-view{background:var(--tn-bg);color:var(--tn-text);border:1px solid var(--tn-border)}
.tn-prop-btn-view:hover{border-color:var(--tn-primary);color:var(--tn-primary)}

/* === SERVICE CARDS === */
.tn-services-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.tn-service-card{background:var(--tn-white);border:1.5px solid var(--tn-border);border-radius:12px;padding:24px 16px;text-align:center;transition:all .3s;cursor:pointer}
.tn-service-card:hover{border-color:var(--tn-primary);box-shadow:var(--tn-shadow-lg);transform:translateY(-4px)}
.tn-service-icon{width:52px;height:52px;background:var(--tn-primary-light);border:1px solid rgba(0,151,178,.12);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:24px}
.tn-service-card h4{font-size:13px;font-weight:700;color:var(--tn-dark);margin-bottom:2px}
.tn-service-card p{font-size:11px;color:var(--tn-text-light)}

/* === DISTRICT TAGS === */
.tn-districts-flex{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.tn-district-tag{background:var(--tn-bg);border:1px solid var(--tn-border);border-radius:6px;padding:7px 16px;font-size:13px;color:var(--tn-text-sec);transition:.2s;cursor:pointer;font-weight:500}
.tn-district-tag:hover{border-color:var(--tn-primary);color:var(--tn-primary);background:var(--tn-primary-light)}
.tn-district-tag.active{background:var(--tn-primary);color:#fff;border-color:var(--tn-primary);font-weight:700}

/* === CTA DUAL === */
.tn-cta-dual{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.tn-cta-card{border-radius:14px;padding:36px 32px;text-align:center;position:relative;overflow:hidden}
.tn-cta-card h3{font-size:1.3rem;font-weight:800;margin-bottom:6px}
.tn-cta-card p{font-size:14px;margin-bottom:20px;opacity:.8}
.tn-cta-property{background:linear-gradient(135deg,var(--tn-accent),#FF8C42);color:#fff}
.tn-cta-property::before{content:'🏠';position:absolute;top:16px;right:24px;font-size:48px;opacity:.15}
.tn-cta-service{background:linear-gradient(135deg,var(--tn-primary),var(--tn-primary-dark));color:#fff}
.tn-cta-service::before{content:'🔧';position:absolute;top:16px;right:24px;font-size:48px;opacity:.15}

/* === WHY CHOOSE === */
.tn-why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tn-why-card{background:var(--tn-white);border:1.5px solid var(--tn-border);border-radius:12px;padding:28px;transition:all .3s}
.tn-why-card:hover{border-color:var(--tn-primary);box-shadow:var(--tn-shadow-lg);transform:translateY(-4px)}
.tn-why-icon{width:48px;height:48px;background:var(--tn-primary-light);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:14px}
.tn-why-card h4{font-size:15px;font-weight:700;color:var(--tn-dark);margin-bottom:6px}
.tn-why-card p{font-size:13px;color:var(--tn-text-sec);line-height:1.6}

/* === PAGE HEADER === */
.tn-page-header{background:var(--tn-dark);color:#fff;padding:40px 0;text-align:center}
.tn-page-header h1{font-size:2rem;font-weight:800;margin-bottom:6px}
.tn-page-header p{font-size:15px;color:rgba(255,255,255,.6)}

/* === BREADCRUMBS === */
.tn-breadcrumbs{padding:14px 0;font-size:13px;color:var(--tn-text-light);background:var(--tn-bg);border-bottom:1px solid var(--tn-border)}
.tn-breadcrumbs a{color:var(--tn-primary);font-weight:500}
.tn-breadcrumbs a:hover{text-decoration:underline}
.tn-breadcrumbs .sep{margin:0 6px;color:var(--tn-border)}

/* === FORMS === */
.tn-form-section{background:var(--tn-white);border:1.5px solid var(--tn-border);border-radius:12px;padding:24px;margin-bottom:20px}
.tn-form-section h3{font-size:16px;font-weight:700;color:var(--tn-dark);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.tn-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.tn-form-field{margin-bottom:14px}
.tn-form-field.full{grid-column:1/-1}
.tn-form-field label{display:block;font-size:12px;font-weight:700;color:var(--tn-text);margin-bottom:4px}
.tn-form-field label .req{color:#EF4444}
.tn-form-field input,.tn-form-field select,.tn-form-field textarea{width:100%;padding:10px 14px;border:1.5px solid var(--tn-border);border-radius:6px;font-size:14px;font-family:var(--tn-font);transition:.2s;background:var(--tn-white)}
.tn-form-field input:focus,.tn-form-field select:focus,.tn-form-field textarea:focus{border-color:var(--tn-primary);outline:none;box-shadow:0 0 0 3px rgba(0,151,178,.1)}
.tn-form-field textarea{min-height:80px;resize:vertical}
.tn-form-hint{font-size:11px;color:var(--tn-text-light);margin-top:3px}
.tn-checkbox-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.tn-checkbox-item{display:flex;align-items:center;gap:6px;font-size:13px;padding:6px 8px;border-radius:4px;cursor:pointer;transition:.15s}
.tn-checkbox-item:hover{background:var(--tn-bg)}
.tn-checkbox-item input{accent-color:var(--tn-primary)}

/* === PLAN SELECTION (add-property / add-service) === */
.tn-plan-step-badge{display:inline-flex;align-items:center;gap:6px;background:var(--tn-primary-light);color:var(--tn-primary);font-size:12px;font-weight:700;padding:5px 14px;border-radius:20px;letter-spacing:.3px}
.tn-plan-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:16px}
.tn-plan-card{border:2px solid var(--tn-border);border-radius:12px;padding:28px 24px;cursor:pointer;transition:all .3s;position:relative;background:var(--tn-white)}
.tn-plan-card:hover{border-color:var(--tn-primary);box-shadow:var(--tn-shadow-lg);transform:translateY(-2px)}
.tn-plan-card.selected{border-color:var(--tn-primary);box-shadow:0 0 0 3px rgba(0,151,178,.15),var(--tn-shadow-lg)}
.tn-plan-card.selected .tn-plan-radio{background:var(--tn-primary);border-color:var(--tn-primary)}
.tn-plan-card.selected .tn-plan-radio::after{content:'✓';color:#fff;font-size:12px;font-weight:700}
.tn-plan-card.premium{border-color:var(--tn-accent);background:linear-gradient(180deg,var(--tn-accent-light),var(--tn-white))}
.tn-plan-card.premium.selected{border-color:var(--tn-accent);box-shadow:0 0 0 3px rgba(255,107,53,.15),var(--tn-shadow-lg)}
.tn-plan-card.premium.selected .tn-plan-radio{background:var(--tn-accent);border-color:var(--tn-accent)}
.tn-plan-radio{width:22px;height:22px;border:2px solid var(--tn-border);border-radius:50%;display:flex;align-items:center;justify-content:center;position:absolute;top:16px;right:16px;transition:.2s}
.tn-plan-popular{position:absolute;top:-11px;left:24px;background:linear-gradient(135deg,var(--tn-accent),var(--tn-accent-hover));color:#fff;font-size:10.5px;font-weight:700;padding:3px 12px;border-radius:10px;letter-spacing:.5px;text-transform:uppercase}
.tn-plan-name{font-size:18px;font-weight:700;color:var(--tn-dark);margin:0 0 4px}
.tn-plan-card.premium .tn-plan-name{color:var(--tn-accent-hover)}
.tn-plan-price{margin:8px 0 16px}
.tn-plan-amount{font-size:1.8rem;font-weight:800;color:var(--tn-dark);line-height:1}
.tn-plan-free-tag{font-size:1.8rem;font-weight:800;color:var(--tn-res)}
.tn-plan-period{font-size:13px;color:var(--tn-text-sec);margin-left:2px}
.tn-plan-desc{font-size:13px;color:var(--tn-text-sec);margin:0 0 16px;line-height:1.5;padding-bottom:14px;border-bottom:1px solid var(--tn-border)}
.tn-plan-features{list-style:none;padding:0;margin:0}
.tn-plan-features li{font-size:13px;color:var(--tn-text);padding:5px 0;display:flex;align-items:flex-start;gap:8px;line-height:1.4}
.tn-plan-features li::before{content:'✅';font-size:12px;flex-shrink:0;margin-top:1px}
.tn-plan-features li.excluded{color:var(--tn-text-sec);opacity:.5}
.tn-plan-features li.excluded::before{content:'—';color:var(--tn-text-sec)}
.tn-plan-select-btn{display:block;width:100%;padding:12px;margin-top:18px;border:2px solid var(--tn-primary);background:transparent;color:var(--tn-primary);font-size:14px;font-weight:700;border-radius:8px;cursor:pointer;transition:.2s;font-family:var(--tn-font)}
.tn-plan-select-btn:hover,.tn-plan-card.selected .tn-plan-select-btn{background:var(--tn-primary);color:#fff}
.tn-plan-select-btn.premium{border-color:var(--tn-accent);color:var(--tn-accent)}
.tn-plan-select-btn.premium:hover,.tn-plan-card.premium.selected .tn-plan-select-btn{background:var(--tn-accent);color:#fff}

/* Plan Banner */
.tn-plan-banner{display:flex;align-items:center;justify-content:space-between;background:var(--tn-primary-light);border:1.5px solid rgba(0,151,178,.2);border-radius:10px;padding:14px 20px;margin-bottom:20px;font-size:14px;flex-wrap:wrap;gap:8px}
.tn-plan-banner.premium{background:var(--tn-accent-light);border-color:rgba(255,107,53,.2)}
.tn-plan-banner strong{color:var(--tn-text)}
.tn-plan-change{color:var(--tn-primary);font-weight:600;cursor:pointer;font-size:13px;text-decoration:underline}
.tn-plan-banner.premium .tn-plan-change{color:var(--tn-accent)}

/* === LISTING SUBMITTED === */
.tn-ls-step{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--tn-text-sec);padding:6px 14px;background:var(--tn-bg);border-radius:20px}
.tn-ls-step.done{background:var(--tn-res-light);color:var(--tn-res);font-weight:600}
.tn-ls-step.current{background:var(--tn-primary-light);color:var(--tn-primary);font-weight:700;border:1.5px solid rgba(0,151,178,.2)}
.tn-ls-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
.tn-ls-card{border:1.5px solid var(--tn-border);border-radius:12px;padding:24px;background:var(--tn-white)}
.tn-ls-card h3{font-size:16px;font-weight:700;color:var(--tn-text);margin:0 0 6px}
.tn-ls-card>p{font-size:13px;color:var(--tn-text-sec);margin:0 0 18px;line-height:1.5}
.tn-ls-payment-card{border-color:var(--tn-accent);background:linear-gradient(180deg,var(--tn-accent-light),var(--tn-white))}
.tn-ls-qr-box{text-align:center;padding:16px;background:var(--tn-white);border:1.5px solid var(--tn-border);border-radius:8px}
.tn-ls-upi-box{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:var(--tn-bg);border:1.5px solid var(--tn-border);border-radius:8px;margin-top:8px}
.tn-ls-upi-box code{font-size:15px;font-weight:700;color:var(--tn-text);font-family:'Courier New',monospace}
.tn-ls-next-steps{background:var(--tn-bg);border:1.5px solid var(--tn-border);border-radius:12px;padding:24px;margin-top:24px}
.tn-ls-next-steps h3{font-size:15px;font-weight:700;color:var(--tn-text);margin:0 0 14px}
.tn-ls-next-steps ol{margin:0;padding-left:20px}
.tn-ls-next-steps li{font-size:13px;color:var(--tn-text);padding:4px 0;line-height:1.5}
.tn-ls-next-steps li strong{color:var(--tn-text)}
.tn-ls-upgrade-box{background:#FFFBEB;border:1.5px solid #FDE68A;border-radius:12px;padding:24px;text-align:center;margin-top:24px}
.tn-ls-upgrade-box h4{font-size:15px;font-weight:700;color:#92400E;margin:0 0 6px}
.tn-ls-upgrade-box p{font-size:13px;color:#A16207;margin:0 0 14px;line-height:1.5}

/* === PAGINATION === */
.tn-pagination{text-align:center;padding:30px 0}
.tn-pagination a,.tn-pagination span{display:inline-block;padding:8px 14px;margin:0 3px;border-radius:6px;font-size:14px;font-weight:600;border:1.5px solid var(--tn-border);color:var(--tn-text-sec);background:var(--tn-white)}
.tn-pagination .current{background:var(--tn-primary);color:#fff;border-color:var(--tn-primary)}
.tn-pagination a:hover{border-color:var(--tn-primary);color:var(--tn-primary)}

/* === 404 === */
.tn-404{text-align:center;padding:80px 0}
.tn-404 h1{font-size:5rem;font-weight:800;color:var(--tn-primary);opacity:.3}
.tn-404 h2{font-size:1.5rem;margin-bottom:12px}

/* === FAQ === */
.tn-faq-section{margin:20px 0}
.tn-faq-title{font-size:1.4rem;font-weight:800;color:var(--tn-dark);margin-bottom:20px;text-align:center}
.tn-faq-list{display:flex;flex-direction:column;gap:10px}
.tn-faq-item{background:var(--tn-white);border:1.5px solid var(--tn-border);border-radius:8px;overflow:hidden;transition:.2s}
.tn-faq-item[open]{border-color:var(--tn-primary);box-shadow:0 2px 12px rgba(0,151,178,.08)}
.tn-faq-question{padding:16px 44px 16px 18px;font-size:14px;font-weight:600;color:var(--tn-dark);cursor:pointer;list-style:none;position:relative;line-height:1.5}
.tn-faq-question::-webkit-details-marker{display:none}
.tn-faq-question::after{content:'+';position:absolute;right:18px;top:50%;transform:translateY(-50%);font-size:20px;font-weight:700;color:var(--tn-primary);transition:.2s}
.tn-faq-item[open] .tn-faq-question::after{content:'−'}
.tn-faq-item[open] .tn-faq-question{color:var(--tn-primary);border-bottom:1px solid var(--tn-border)}
.tn-faq-answer{padding:16px 18px;font-size:14px;color:var(--tn-text-sec);line-height:1.7}

/* === SINGLE PROPERTY PAGE === */
.tn-single-prop{padding:30px 0 60px}
.tn-single-prop .container{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:start}
.tn-prop-gallery{border-radius:12px;overflow:hidden;border:1.5px solid var(--tn-border);background:var(--tn-bg)}
.tn-prop-gallery img{width:100%;height:auto;max-height:450px;object-fit:cover}
.tn-prop-gallery-thumbs{display:flex;gap:6px;padding:10px;overflow-x:auto}
.tn-prop-gallery-thumbs img{width:64px;height:64px;object-fit:cover;border-radius:6px;border:2px solid var(--tn-border);cursor:pointer;flex-shrink:0}
.tn-prop-gallery-thumbs img.active,.tn-prop-gallery-thumbs img:hover{border-color:var(--tn-primary)}
.tn-prop-detail-header h1{font-size:1.5rem;font-weight:800;color:var(--tn-dark);margin-bottom:6px}
.tn-prop-detail-price{font-size:1.6rem;font-weight:800;color:var(--tn-primary);font-family:var(--tn-font-head);margin-bottom:12px}
.tn-prop-detail-price small{font-size:14px;font-weight:500;color:var(--tn-text-light)}
.tn-prop-detail-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.tn-prop-meta-tag{font-size:12px;padding:4px 10px;border-radius:4px;font-weight:600}
.tn-prop-detail-specs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:16px 0}
.tn-prop-detail-spec{background:var(--tn-bg);border-radius:8px;padding:12px;text-align:center}
.tn-prop-detail-spec strong{display:block;font-size:16px;color:var(--tn-dark);font-weight:800}
.tn-prop-detail-spec span{font-size:11px;color:var(--tn-text-light)}

/* === FOOTER === */
.tn-footer{background:var(--tn-dark);color:rgba(255,255,255,.55);padding:48px 0 0}
.tn-footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:32px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
.tn-footer h4{color:#fff;font-size:14px;font-weight:700;margin-bottom:14px}
.tn-footer-about p{font-size:13px;line-height:1.7;margin-bottom:8px}
.tn-footer-links{list-style:none}
.tn-footer-links li{margin-bottom:6px}
.tn-footer-links a{font-size:13px;color:rgba(255,255,255,.45);transition:.2s}
.tn-footer-links a:hover{color:var(--tn-accent);padding-left:4px}
.tn-footer-contact p{font-size:13px;margin-bottom:8px}
.tn-footer-bottom{padding:18px 0;text-align:center;font-size:12px;color:rgba(255,255,255,.25)}
.tn-footer-bottom a{color:var(--tn-accent)}

/* === FLOATING WHATSAPP === */
.tn-wa-float{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;align-items:center;gap:10px}
.tn-wa-float-btn{width:58px;height:58px;background:var(--tn-wa);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.35);cursor:pointer;animation:pulse 2s infinite;font-size:28px;color:#fff}
.tn-wa-float-btn:hover{transform:scale(1.08)}
.tn-wa-float-label{background:var(--tn-dark);color:#fff;padding:7px 13px;border-radius:8px;font-size:12px;font-weight:600;white-space:nowrap;box-shadow:var(--tn-shadow-lg)}

/* === RESPONSIVE === */
@media(max-width:1024px){
.tn-type-grid{grid-template-columns:repeat(2,1fr)}
.tn-prop-grid{grid-template-columns:repeat(2,1fr)}
.tn-services-grid{grid-template-columns:repeat(3,1fr)}
.tn-why-grid{grid-template-columns:1fr 1fr}
.tn-footer-grid{grid-template-columns:1fr 1fr}
.tn-search-filters{grid-template-columns:1fr 1fr}
.tn-cta-dual{grid-template-columns:1fr}
.tn-single-prop .container{grid-template-columns:1fr}
.tn-ls-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
.tn-hero h1{font-size:1.7rem}
.tn-hero{padding:45px 0 40px}
.tn-nav{display:none}
.tn-mobile-toggle{display:block}
.tn-nav.active{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--tn-white);padding:16px;box-shadow:var(--tn-shadow-lg);border-top:1px solid var(--tn-border);z-index:99}
.tn-type-grid{grid-template-columns:1fr 1fr}
.tn-prop-grid{grid-template-columns:1fr}
.tn-services-grid{grid-template-columns:1fr 1fr}
.tn-why-grid{grid-template-columns:1fr}
.tn-footer-grid{grid-template-columns:1fr}
.tn-search-filters{grid-template-columns:1fr}
.tn-form-row,.tn-checkbox-grid{grid-template-columns:1fr}
.tn-plan-cards{grid-template-columns:1fr}
.tn-hero-stats{gap:20px}
.tn-topbar .container{justify-content:center;text-align:center}
.tn-prop-detail-specs{grid-template-columns:repeat(2,1fr)}
html,body{overflow-x:hidden;max-width:100vw}
}
