@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600&family=Cormorant+Garamond:ital,wght@0,400;0,500;1,400&family=Montserrat:wght@300;400;500;600&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{--gold:#c9a84c;--gold-soft:#d4b95e;--gold-deep:#a8862f;}
html[data-theme="dark"]{--bg:#0a0a0a;--bg2:#121212;--bg3:#1a1a1a;--border:#2a2a2a;--border-soft:#222;--text:#f0ece2;--text-dim:#9a948a;--text-muted:#5f5b54;--accent:var(--gold);--on-accent:#0a0a0a;--shadow:0 8px 30px rgba(0,0,0,.5);--map-tiles:dark_all;}
html[data-theme="light"]{--bg:#faf8f3;--bg2:#ffffff;--bg3:#f4f1e9;--border:#e6e0d2;--border-soft:#efe9db;--text:#1c1a16;--text-dim:#6b6557;--text-muted:#a39d8e;--accent:var(--gold-deep);--on-accent:#ffffff;--shadow:0 8px 30px rgba(120,100,40,.1);--map-tiles:light_all;}
body{background:var(--bg);color:var(--text);font-family:'Montserrat',sans-serif;font-size:16.5px;line-height:1.62;min-height:100vh;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s;}
html[dir="rtl"] body{font-family:'Montserrat','Segoe UI',Tahoma,sans-serif;}
h1,h2,h3,.serif{font-family:'Cinzel',serif;font-weight:500;letter-spacing:.02em;}
.display{font-family:'Cormorant Garamond',serif;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}

/* TOPBAR */
.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:58px;background:var(--bg2);border-bottom:1px solid var(--border);}
.topbar .brand{display:flex;align-items:center;gap:10px;}
.brand-mark{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--accent);display:flex;align-items:center;justify-content:center;}
.brand-mark span{font-family:'Cinzel',serif;font-size:8px;color:var(--accent);letter-spacing:.14em;}
.brand-name{font-family:'Cinzel',serif;font-size:14px;letter-spacing:.16em;color:var(--text);}
.topbar-controls{display:flex;align-items:center;gap:8px;}
.topbar-user{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2;margin-right:4px;}
.topbar-user .tu-name{font-size:13.5px;font-weight:600;color:var(--text);white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis;}
.topbar-user .tu-tier{font-family:'Cinzel',serif;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-top:1px;}
@media(max-width:560px){.topbar-user .tu-name{max-width:96px;font-size:12px;}.topbar-user .tu-tier{font-size:8.5px;}}
.icon-btn{width:34px;height:34px;border-radius:50%;background:none;border:1px solid var(--border);color:var(--text-dim);display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s;}
.icon-btn:hover{border-color:var(--accent);color:var(--accent);}
.lang-select{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:20px;padding:6px 12px;font-size:13px;font-family:inherit;outline:none;cursor:pointer;}

/* TOP NAV */
.top-nav{position:sticky;top:58px;z-index:90;display:flex;background:var(--bg2);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.top-nav::-webkit-scrollbar{display:none;}
.tn-item{flex:1;min-width:70px;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 8px;color:var(--text-muted);border:none;background:none;border-bottom:2px solid transparent;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;transition:all .15s;white-space:nowrap;}
.tn-item i{font-size:17px;}
.tn-item.active{color:var(--accent);border-bottom-color:var(--accent);}
.tn-item:hover{color:var(--text);}

/* APP LAYOUT */
.app-shell{max-width:1040px;margin:0 auto;padding:24px 22px 48px;}
.screen{display:none;animation:fade .22s ease;}
.screen.active{display:block;}
@keyframes fade{from{opacity:0;transform:translateY(5px);}to{opacity:1;transform:none;}}

/* CARDS */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:22px;margin-bottom:16px;}
.section-title{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;}

/* WELCOME BANNER */
.welcome{position:relative;border-radius:16px;overflow:hidden;margin-bottom:20px;min-height:160px;display:flex;align-items:flex-end;background:var(--bg3);}
.welcome img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55;}
.welcome::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);}
html[data-theme="light"] .welcome::after{background:linear-gradient(to top,rgba(28,26,22,.55),transparent);}
.welcome-text{position:relative;z-index:2;padding:22px;color:#fff;}
.welcome-text h1{font-size:22px;color:#fff;margin-bottom:5px;}
.welcome-text p{color:rgba(255,255,255,.85);font-size:13px;}
.welcome-tier{display:inline-block;margin-top:8px;background:rgba(201,168,76,.25);border:1px solid var(--accent);color:#fff;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:3px 11px;border-radius:20px;}

/* QUICK ACTIONS */
.qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.qa{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center;transition:all .15s;}
.qa:hover{border-color:var(--accent);transform:translateY(-2px);}
.qa i{font-size:20px;color:var(--accent);margin-bottom:8px;display:block;}
.qa span{font-size:13.5px;color:var(--text);font-weight:500;}

/* MAP */
.map-wrap{position:relative;z-index:1;border-radius:14px;overflow:hidden;border:1px solid var(--border);margin-bottom:16px;height:calc(100vh - 200px);min-height:620px;}
.map-toggle{display:flex;gap:8px;margin-bottom:12px;}
.map-toggle .mt-btn{flex:1;padding:11px 14px;border-radius:10px;border:1px solid var(--border);background:var(--card,#fff);color:var(--muted,#888);font-weight:700;font-size:12px;letter-spacing:.08em;cursor:pointer;transition:all .15s;}
.map-toggle .mt-btn.active{background:var(--accent);border-color:var(--accent);color:#1a1a1a;}
.place-pop{min-width:160px;}
.place-pop .pp-name{font-weight:700;font-size:14px;margin-bottom:3px;}
.place-pop .pp-desc{font-size:12px;color:#555;line-height:1.4;}
.place-pop .pp-addr{font-size:11px;color:#888;margin-top:5px;}
.place-pop .pp-links{display:flex;gap:10px;margin-top:8px;}
.place-pop .pp-links a{font-size:12px;font-weight:600;color:#2563eb;text-decoration:none;}
.place-pop .pp-cat{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#2563eb;background:rgba(37,99,235,.1);padding:2px 8px;border-radius:20px;margin-bottom:5px;}
.place-cat-bar{margin-bottom:12px;}
.place-cat-bar select{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--card,#fff);color:var(--text);font-size:13px;}
.field-row{display:flex;gap:12px;}
.field-row .field{flex:1;}
#memberCal{--fc-border-color:var(--border);--fc-page-bg-color:transparent;--fc-neutral-bg-color:var(--bg3);--fc-today-bg-color:rgba(201,168,76,.08);--fc-button-bg-color:var(--accent);--fc-button-border-color:var(--accent);--fc-button-text-color:var(--on-accent);--fc-button-hover-bg-color:var(--accent);--fc-button-active-bg-color:var(--accent);font-size:13px;}
#memberCal .fc-toolbar-title{font-size:16px;color:var(--text);}
#memberCal .fc-col-header-cell-cushion,#memberCal .fc-daygrid-day-number,#memberCal .fc-list-day-text,#memberCal .fc-list-event-title{color:var(--text);text-decoration:none;}
#memberCal .fc-daygrid-day-number{color:var(--text-dim);}
#memberCal a{color:var(--text);}
#memberCal .fc-button{text-transform:capitalize;font-weight:600;box-shadow:none!important;}
#memberCal .fc-list,#memberCal .fc-scrollgrid{border-color:var(--border);}
.cal-key{display:flex;flex-wrap:wrap;gap:16px;margin:12px 2px 16px;font-size:12px;color:var(--text-dim);}
.cal-key span{display:inline-flex;align-items:center;gap:6px;}
.cal-key i{width:11px;height:11px;border-radius:3px;display:inline-block;}
.bio-lock{position:fixed;inset:0;z-index:5000;background:var(--bg);display:none;align-items:center;justify-content:center;padding:24px;}
.bio-lock.open{display:flex;}
.bio-lock-card{text-align:center;max-width:320px;}
.bio-lock-card>i{font-size:54px;color:var(--accent);margin-bottom:18px;}
.bio-lock-title{font-family:'Cinzel',serif;font-size:20px;color:var(--text);margin-bottom:6px;}
.bio-lock-sub{font-size:13px;color:var(--text-dim);margin-bottom:22px;}
.bio-lock-card .btn{width:100%;margin-bottom:10px;}
.btn-link{background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;text-decoration:underline;}
.sec-modal{position:fixed;inset:0;z-index:5200;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;padding:20px;}
.sec-modal.open{display:flex;}
.sec-modal-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;max-width:380px;width:100%;max-height:92vh;overflow:auto;}
.sec-modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);font-family:'Cinzel',serif;font-size:14px;color:var(--text);}
.sec-x{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;}
.sec-modal-body{padding:20px;text-align:center;}
.sec-step{font-size:13px;color:var(--text-dim);margin:0 0 14px;}
.mfa-qr{display:flex;justify-content:center;padding:12px;background:#fff;border-radius:10px;width:max-content;margin:0 auto 14px;}
.sec-manual{font-size:12px;color:var(--text-muted);margin:0 0 16px;word-break:break-all;}
.sec-manual code{color:var(--accent);font-size:13px;letter-spacing:.05em;}
.sec-code-input{width:100%;text-align:center;font-size:24px;letter-spacing:.4em;padding:12px;border-radius:10px;border:1px solid var(--border);background:var(--bg3);color:var(--text);margin-bottom:14px;font-family:monospace;}
.sec-modal-body .btn{width:100%;margin-bottom:8px;}
.chat-icon-btn.ttl-on{color:var(--accent);}
.chat-icon-btn .ttl-tag{font-size:9px;font-weight:700;margin-left:2px;vertical-align:top;}
.chat-dis{font-size:10px;margin-right:4px;opacity:.7;}
#memberMap{height:100%;width:100%;}
.map-panel{position:fixed;bottom:0;left:0;right:0;z-index:1200;background:var(--bg2);border-top:1px solid var(--border);border-radius:20px 20px 0 0;padding:20px;max-height:70vh;overflow-y:auto;transform:translateY(100%);transition:transform .3s ease;box-shadow:0 -4px 30px rgba(0,0,0,.2);}
.map-panel.open{transform:translateY(0);}
.panel-handle{width:40px;height:4px;background:var(--border);border-radius:4px;margin:0 auto 16px;}
.panel-country{font-family:'Cinzel',serif;font-size:16px;color:var(--text);margin-bottom:4px;}
.panel-close{position:absolute;top:16px;right:20px;background:none;border:none;color:var(--text-muted);font-size:18px;}
.panel-overlay{position:fixed;inset:0;z-index:1100;background:rgba(0,0,0,.4);display:none;}
.panel-overlay.open{display:block;}
.no-agents{color:var(--text-muted);font-size:13px;text-align:center;padding:16px 0;}

/* AGENT */
.agent-head{display:flex;align-items:center;gap:14px;margin-bottom:18px;}
.agent-photo{width:68px;height:68px;border-radius:50%;object-fit:cover;border:2px solid var(--accent);}
.agent-photo-ph{width:68px;height:68px;border-radius:50%;background:var(--bg3);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:24px;}
.agent-name{font-family:'Cinzel',serif;font-size:17px;color:var(--text);}
.agent-role{color:var(--accent);font-size:12px;margin-top:2px;}
.agent-city{color:var(--text-muted);font-size:11px;}
.rm-note{background:var(--bg3);border-inline-start:3px solid var(--accent);border-radius:0 10px 10px 0;padding:12px 16px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;color:var(--text-dim);margin-bottom:18px;}
html[dir="rtl"] .rm-note{border-radius:10px 0 0 10px;}
.channel{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;margin-bottom:9px;transition:all .15s;}
.channel:hover{border-color:var(--accent);}
.ch-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.ch-wa{background:rgba(37,211,102,.15);color:#25d366;}
.ch-ph{background:rgba(201,168,76,.15);color:var(--accent);}
.ch-em{background:rgba(66,153,225,.15);color:#4299e1;}
.ch-sg{background:rgba(63,131,248,.15);color:#3f83f8;}
.ch-tg{background:rgba(0,136,204,.15);color:#0088cc;}
.ch-body{flex:1;}
.ch-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);}
.ch-value{font-size:14.5px;color:var(--text);margin-top:1px;}
.ch-arrow{color:var(--text-muted);font-size:12px;}
.locked-badge{display:inline-flex;align-items:center;gap:6px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text-muted);margin-bottom:9px;width:100%;}

/* FORMS */
.field{margin-bottom:14px;}
label{display:block;font-size:11px;letter-spacing:.04em;color:var(--text-dim);margin-bottom:6px;text-transform:uppercase;}
input,select,textarea{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:12px 14px;border-radius:10px;font-size:15px;font-family:inherit;outline:none;transition:border-color .15s;}
input:focus,select:focus,textarea:focus{border-color:var(--accent);}
textarea{resize:vertical;min-height:86px;}
input[readonly]{opacity:.7;cursor:default;}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--accent);color:var(--on-accent);border:none;border-radius:10px;padding:13px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:opacity .15s;}
.btn:hover{opacity:.9;}
.btn:disabled{opacity:.5;cursor:not-allowed;}
.btn-ghost{background:none;border:1px solid var(--border);color:var(--text-dim);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);}

/* PROFILE TABS */
.ptabs{display:flex;gap:4px;overflow-x:auto;margin-bottom:18px;border-bottom:1px solid var(--border);scrollbar-width:none;}
.ptabs::-webkit-scrollbar{display:none;}
.ptab{padding:9px 13px;background:none;border:none;color:var(--text-dim);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-bottom:2px solid transparent;transition:all .15s;}
.ptab.active{color:var(--accent);border-bottom-color:var(--accent);}
.ppane{display:none;}
.ppane.active{display:block;}
.detail-row{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border-soft);gap:16px;}
.detail-row:last-child{border-bottom:none;}
.detail-label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);flex-shrink:0;}
.detail-value{font-size:14.5px;color:var(--text);text-align:end;}

/* LOGIN */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;}
.login-card{width:100%;max-width:400px;background:var(--bg2);border:1px solid var(--border);border-radius:18px;padding:38px 32px;box-shadow:var(--shadow);}
.login-brand{text-align:center;margin-bottom:28px;}
.login-brand .mark{width:60px;height:60px;border-radius:50%;border:1.5px solid var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;}
.login-brand .mark span{font-family:'Cinzel',serif;font-size:11px;color:var(--accent);letter-spacing:.16em;}
.login-brand h1{font-size:17px;letter-spacing:.06em;margin-bottom:3px;}
.login-brand p{color:var(--text-muted);font-size:12px;}
.login-controls{display:flex;justify-content:center;gap:10px;margin-top:22px;}
.forgot-pw-btn{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;text-decoration:underline;text-underline-offset:2px;margin-top:10px;display:block;width:100%;text-align:center;transition:color .15s;}
.forgot-pw-btn:hover{color:var(--accent);}
.pwd-wrap{position:relative;}
.pwd-toggle{position:absolute;inset-inline-end:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:13px;}

/* TOAST */
.toast{position:fixed;top:80px;left:50%;transform:translateX(-50%);background:var(--bg3);border:1px solid var(--accent);color:var(--text);padding:11px 20px;border-radius:30px;font-size:12px;z-index:300;opacity:0;transition:opacity .3s;pointer-events:none;white-space:nowrap;}
.toast.show{opacity:1;}
.toast.err{border-color:#e24b4a;color:#e24b4a;}

/* LEAFLET OVERRIDES */
.leaflet-container{background:var(--bg3);z-index:1;}
html[data-theme="dark"] .leaflet-popup-content-wrapper{background:#1a1a1a;color:#f0ece2;border:1px solid #2a2a2a;}
html[data-theme="dark"] .leaflet-popup-tip{background:#1a1a1a;}
.leaflet-popup-content-wrapper{border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.15);}

.muted{color:var(--text-muted);font-size:13px;}
.center{text-align:center;}
.mt{margin-top:12px;}
.hidden{display:none!important;}
.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:currentColor;border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* NOTIFICATIONS */
.bell-wrap{position:relative;}
.bell-badge{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;background:#e24b4a;border-radius:8px;font-size:10px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;padding:0 3px;pointer-events:none;}
.bell-badge.hidden{display:none;}
.notif-item{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:16px 18px;margin-bottom:10px;position:relative;transition:border-color .15s;}
.notif-item.unread{border-color:var(--accent);background:var(--bg3);}
.notif-item.unread::before{content:"";position:absolute;top:16px;inset-inline-start:16px;width:7px;height:7px;border-radius:50%;background:var(--accent);}
.notif-title{font-weight:600;font-size:14px;color:var(--text);margin-bottom:4px;padding-inline-start:16px;}
.notif-item.unread .notif-title{padding-inline-start:18px;}
.notif-body{font-size:13px;color:var(--text-dim);line-height:1.5;padding-inline-start:16px;}
.notif-date{font-size:11px;color:var(--text-muted);margin-top:8px;padding-inline-start:16px;}
.notif-empty{text-align:center;padding:48px 0;color:var(--text-muted);}
.notif-empty i{font-size:32px;color:var(--accent);display:block;margin-bottom:12px;}

/* TIER BENEFITS */
.tier-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:16px;}
.tier-badge-name{display:inline-flex;align-items:center;gap:8px;background:rgba(201,168,76,.12);border:1px solid var(--accent);border-radius:20px;padding:5px 14px;font-family:'Cinzel',serif;font-size:12px;color:var(--accent);letter-spacing:.1em;margin-bottom:14px;}
.tier-benefits-list{list-style:none;padding:0;}
.tier-benefits-list li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-soft);font-size:13px;color:var(--text-dim);}
.tier-benefits-list li:last-child{border-bottom:none;}
.tier-benefits-list li i{color:var(--accent);font-size:12px;margin-top:3px;flex-shrink:0;}

/* ARTICLES */
.article-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:14px;transition:border-color .15s;}
.article-card:hover{border-color:var(--accent);}
.article-img-banner{width:100%;height:160px;object-fit:cover;display:block;}
.article-body{padding:16px;}
.article-tier-badge{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:6px;}
.article-title{font-family:'Cinzel',serif;font-size:15px;color:var(--text);margin-bottom:6px;line-height:1.4;}
.article-excerpt{font-size:13px;color:var(--text-dim);line-height:1.5;}
.article-date{font-size:11px;color:var(--text-muted);margin-top:8px;}
.article-full-body{font-size:14px;color:var(--text-dim);line-height:1.7;white-space:pre-wrap;}

/* PREF CATEGORIES */
.pref-category{margin-bottom:20px;}
.pref-cat-title{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--border);padding-bottom:10px;margin-bottom:16px;}
.pref-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.pref-grid .full{grid-column:1/-1;}
@media(max-width:500px){.pref-grid{grid-template-columns:1fr;}.pref-grid .full{grid-column:1;}}

/* TIER ADVANTAGES */
.tier-card{margin-top:4px;}
.tier-card-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.tier-card-head i{color:var(--accent);font-size:18px;}
.tier-card-head span{font-family:'Cinzel',serif;font-size:15px;color:var(--text);}
.benefit-list{list-style:none;}
.benefit-list li{display:flex;align-items:flex-start;gap:10px;padding:7px 0;font-size:13.5px;color:var(--text-dim);}
.benefit-list li i{color:var(--accent);font-size:12px;margin-top:4px;flex-shrink:0;}

/* NEWS */
.news-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:14px;cursor:pointer;transition:border-color .15s,transform .15s;}
.news-card:hover{border-color:var(--accent);transform:translateY(-2px);}
.news-img{width:100%;height:150px;object-fit:cover;display:block;}
.news-body{padding:16px 18px;}
.news-card-title{font-family:'Cinzel',serif;font-size:15px;color:var(--text);margin-bottom:4px;}
.news-card-date{font-size:11px;color:var(--text-muted);}
.news-excerpt{font-size:13px;color:var(--text-dim);margin-top:8px;line-height:1.5;}
.news-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.96);z-index:200;background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:24px;max-width:560px;width:calc(100% - 32px);max-height:84vh;overflow-y:auto;opacity:0;pointer-events:none;transition:all .25s;}
.news-modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1);}
.news-detail-img{width:100%;max-height:240px;object-fit:cover;border-radius:12px;margin-bottom:16px;}
.news-detail-title{font-family:'Cinzel',serif;font-size:20px;color:var(--text);margin-bottom:4px;}
.news-detail-text{font-size:14px;color:var(--text-dim);line-height:1.7;}

/* PREFERENCE CATEGORIES */
.pref-cat-head{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);}
.pref-cat-head i{color:var(--accent);font-size:16px;width:20px;text-align:center;}
.pref-cat-head span{font-family:'Cinzel',serif;font-size:13px;letter-spacing:.06em;color:var(--text);text-transform:uppercase;}

/* ── CMS-driven home + about additions ── */
.announce-card{display:flex;gap:12px;align-items:flex-start;background:linear-gradient(135deg,rgba(201,168,76,.16),rgba(201,168,76,.06));border:1px solid var(--accent);border-radius:12px;padding:14px 16px;margin-bottom:16px;color:var(--text);font-size:14.5px;line-height:1.5;}
.announce-card i{color:var(--accent);font-size:16px;margin-top:2px;}
.featured-card{padding:0;overflow:hidden;}
.featured-img{width:100%;height:170px;object-fit:cover;display:block;}
.featured-body{padding:16px;}
.featured-title{font-family:'Cinzel',serif;font-size:16px;color:var(--text);margin-bottom:6px;}
.featured-text{font-size:14px;color:var(--text-dim);line-height:1.55;}
.legal-acc{cursor:pointer;}
.legal-acc>summary{list-style:none;cursor:pointer;font-family:'Cinzel',serif;font-size:13px;letter-spacing:.06em;color:var(--text);display:flex;align-items:center;justify-content:space-between;}
.legal-acc>summary::-webkit-details-marker{display:none;}
.legal-acc>summary::after{content:'\002B';color:var(--accent);font-size:18px;}
.legal-acc[open]>summary::after{content:'\2212';}
.legal-body{white-space:pre-wrap;line-height:1.6;color:var(--text-dim);margin-top:12px;font-size:14px;}
.brief-card{padding:14px 16px;}
.brief-card>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.brief-card>summary::-webkit-details-marker{display:none;}
.brief-summary{display:flex;flex-direction:column;gap:2px;}
.brief-country{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);}
.brief-title{font-family:'Cinzel',serif;font-size:15px;color:var(--text);}
.brief-chev{color:var(--text-muted);transition:transform .2s;}
.brief-card[open] .brief-chev{transform:rotate(180deg);}
.brief-img{width:100%;max-height:180px;object-fit:cover;border-radius:10px;margin:12px 0;}
.brief-body{font-size:14px;line-height:1.6;color:var(--text-dim);}

/* ── Round icon buttons (fix oval) ── */
.icon-btn{flex:0 0 auto;aspect-ratio:1/1;padding:0;}

/* ── Real logo in round frames ── */
.brand-mark{overflow:hidden;padding:0;}
.brand-mark img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block;}
.login-brand .mark{overflow:hidden;}
.login-brand .mark img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block;}

/* ── Sans-serif font mode (toggle) ── */
html[data-font="sans"] body{font-size:17.5px;}
html[data-font="sans"] .serif,
html[data-font="sans"] .brand-name,
html[data-font="sans"] .section-title,
html[data-font="sans"] .welcome-text h1,
html[data-font="sans"] .agent-name,
html[data-font="sans"] .panel-country,
html[data-font="sans"] .featured-title,
html[data-font="sans"] .brief-title,
html[data-font="sans"] .tier-card-head span,
html[data-font="sans"] .legal-acc>summary,
html[data-font="sans"] .rm-note{font-family:'Montserrat',Arial,Helvetica,sans-serif !important;font-style:normal;}

/* ── Share location button ── */
.btn-loc{background:var(--bg2);color:var(--text);border:1px solid var(--border);margin-top:12px;margin-bottom:16px;}
.btn-loc.loc-active{background:var(--accent);color:var(--on-accent);border-color:var(--accent);}

/* ── Home footer About & Legal link ── */
.home-foot{margin-top:30px;padding-top:18px;border-top:1px solid var(--border);text-align:center;}
.about-link{background:none;border:none;color:var(--text-muted);font-size:13px;letter-spacing:.04em;cursor:pointer;display:inline-flex;align-items:center;gap:7px;padding:8px 12px;}
.about-link:hover{color:var(--accent);}

.icon-btn.font-active{background:var(--accent);color:var(--on-accent);border-color:var(--accent);}

/* ── About/news modal above overlay (fix dark-screen + clickable) ── */
.news-modal{z-index:1200 !important;}

/* ── Profile photo upload ── */
.profile-photo-wrap{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:16px;}
.profile-photo{width:74px;height:74px;border-radius:50%;object-fit:cover;border:2px solid var(--accent);}
.profile-photo-ph{width:74px;height:74px;border-radius:50%;background:var(--bg3);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:26px;}
.photo-upload-btn{display:inline-flex;align-items:center;gap:7px;background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:9px 14px;font-size:13px;cursor:pointer;text-transform:none;letter-spacing:0;}
.photo-upload-btn:hover{border-color:var(--accent);color:var(--accent);}

/* ── My Requests cards + status badges ── */
.req-card{cursor:pointer;padding:14px 16px;margin-bottom:10px;}
.req-card-top{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.req-svc{font-weight:600;color:var(--text);}
.req-card-sub{font-size:12.5px;color:var(--text-muted);margin-top:3px;}
.req-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:3px 9px;border-radius:20px;white-space:nowrap;}
.badge-pending{background:rgba(201,168,76,.18);color:var(--accent);}
.badge-approved{background:rgba(46,160,90,.16);color:#2ea05a;}
.badge-completed{background:rgba(60,110,200,.16);color:#3c6ec8;}
.badge-rejected{background:rgba(200,60,60,.14);color:#c83c3c;}
.badge-canceled{background:rgba(140,140,140,.18);color:#9a9a9a;}
.btn-cancel{background:none;border:1px solid #c83c3c;color:#c83c3c;margin-top:6px;}
.btn-cancel:hover{background:#c83c3c;color:#fff;}

/* ── Settings tab ── */
.set-group{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;}
.set-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--text);}
.set-row:last-child{border-bottom:none;}
.set-hint{font-size:12px;color:var(--text-muted);margin-top:4px;}
.set-select,.set-time{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:9px;padding:7px 9px;font-size:13px;}
.switch{position:relative;display:inline-block;width:44px;height:25px;flex:0 0 auto;}
.switch input{opacity:0;width:0;height:0;}
.switch .slider{position:absolute;inset:0;cursor:pointer;background:var(--bg3);border:1px solid var(--border);border-radius:25px;transition:.2s;}
.switch .slider:before{content:"";position:absolute;height:19px;width:19px;left:2px;top:2px;background:#fff;border-radius:50%;transition:.2s;}
.switch input:checked + .slider{background:var(--accent);border-color:var(--accent);}
.switch input:checked + .slider:before{transform:translateX(19px);}

/* ── 24/7 Chat CTA (top of My Agent) ── */
.chat-cta{display:flex;align-items:center;gap:13px;width:100%;text-align:left;border:none;cursor:pointer;background:linear-gradient(135deg,#1a1a1a,#2b2415);border:1px solid var(--accent);border-radius:16px;padding:15px;margin-bottom:14px;position:relative;}
.chat-cta-ic{width:46px;height:46px;border-radius:50%;flex:0 0 auto;background:var(--accent);color:#1a1a1a;display:flex;align-items:center;justify-content:center;font-size:20px;}
.chat-cta-t{font-size:15px;font-weight:700;color:var(--accent);}
.chat-cta-s{font-size:12px;color:var(--text-muted);margin-top:1px;}
.chat-cta-badge{position:absolute;top:11px;right:13px;background:#e53e3e;color:#fff;font-size:11px;font-weight:700;border-radius:11px;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;padding:0 5px;}

/* ── Chat overlay ── */
.chat-modal{position:fixed;inset:0;z-index:1200;background:var(--bg);display:flex;flex-direction:column;transform:translateY(100%);transition:transform .25s ease;}
.chat-modal.open{transform:translateY(0);}
.chat-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;background:#14130f;border-bottom:1px solid var(--accent);padding-top:calc(14px + env(safe-area-inset-top));}
.chat-head-id{display:flex;align-items:center;gap:11px;min-width:0;}
.chat-avatar{width:42px;height:42px;border-radius:50%;flex:0 0 auto;background-size:cover;background-position:center;background-color:#2a2a2a;color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;border:1px solid var(--accent);}
.chat-title{font-size:16px;font-weight:700;color:#f5f5f5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chat-sub{font-size:11px;color:var(--accent);}
.chat-close{background:transparent;border:none;color:#bbb;font-size:20px;cursor:pointer;padding:6px;}
.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:9px;background:var(--bg);}
.chat-note{margin:auto;text-align:center;color:var(--text-muted);font-size:13px;max-width:280px;line-height:1.5;}
.chat-bubble{max-width:78%;padding:9px 13px;border-radius:15px;font-size:14px;line-height:1.45;word-wrap:break-word;white-space:pre-wrap;}
.chat-bubble .chat-time{display:block;font-size:10px;opacity:.6;margin-top:4px;}
.chat-bubble.me{align-self:flex-end;background:var(--accent);color:#1a1a1a;border-bottom-right-radius:5px;}
.chat-bubble.them{align-self:flex-start;background:#2a2a2a;color:#f0f0f0;border-bottom-left-radius:5px;}
.chat-input-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--border);background:var(--bg2);position:relative;padding-bottom:calc(10px + env(safe-area-inset-bottom));}
.chat-input{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:22px;padding:11px 15px;font-size:14px;}
.chat-icon-btn,.chat-send{width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;flex:0 0 auto;font-size:16px;}
.chat-icon-btn{background:var(--bg3);color:var(--text-muted);}
.chat-send{background:var(--accent);color:#1a1a1a;}
.emoji-tray{position:absolute;bottom:58px;left:12px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:8px;display:none;grid-template-columns:repeat(8,1fr);gap:3px;max-width:88vw;z-index:5;}
.emoji-tray.open{display:grid;}
.emoji-tray span{cursor:pointer;font-size:20px;text-align:center;padding:3px;border-radius:6px;}
.emoji-tray span:active{background:var(--bg3);}
.chat-unlock{margin:auto;text-align:center;color:var(--text);display:flex;flex-direction:column;gap:11px;align-items:center;max-width:280px;}
.chat-unlock i{font-size:30px;color:var(--accent);}
.chat-unlock p{font-size:13px;color:var(--text-muted);margin:0;line-height:1.5;}
.chat-unlock input{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:11px;font-size:14px;}
.chat-archived{background:var(--bg2);border-bottom:1px solid var(--border);color:var(--text-muted);font-size:12px;text-align:center;padding:8px 12px;}

/* ── LOGIN BACKGROUND ───────────────────────────────────────────────────── */
html[data-theme="dark"]  .login-wrap{background-image:url('https://admin.algozgroup.com/images/ls-app-d.jpg');}
html[data-theme="light"] .login-wrap{background-image:url('https://admin.algozgroup.com/images/ls-app-l.jpg');}
.login-wrap{background-size:cover;background-position:center;background-repeat:no-repeat;position:relative;}
.login-wrap::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.42);pointer-events:none;z-index:0;}
.login-wrap-inner{position:relative;z-index:1;width:100%;max-width:440px;display:flex;flex-direction:column;align-items:center;gap:0;}
.login-wrap{justify-content:center;align-items:center;}

/* Glass card on background */
.login-card{background:rgba(10,10,10,.72)!important;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(201,168,76,.22)!important;}
html[data-theme="light"] .login-card{background:rgba(250,248,243,.82)!important;}
.login-card .login-brand h1{color:#f0ece2;}
.login-card .login-brand p{color:rgba(240,236,226,.55);}
html[data-theme="light"] .login-card .login-brand h1{color:var(--text);}
html[data-theme="light"] .login-card .login-brand p{color:var(--text-muted);}

/* Become a member strip */
.become-member{text-align:center;padding:22px 16px 0;width:100%;}
.bm-top{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:7px;}
.bm-line{font-size:13px;color:rgba(240,236,226,.75);}
html[data-theme="light"] .bm-line{color:rgba(255,255,255,.9);}
.bm-link{color:var(--gold);font-weight:600;text-decoration:underline;text-underline-offset:3px;transition:opacity .15s;}
.bm-link:hover{opacity:.75;}

/* ── APPLY VIEW ──────────────────────────────────────────────────────────── */
.apply-page{min-height:100vh;background:var(--bg);color:var(--text);}

.apply-topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;padding:0 20px;height:54px;background:var(--bg2);border-bottom:1px solid var(--border);}
.apply-back{background:none;border:none;color:var(--text-dim);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;letter-spacing:.04em;padding:0;transition:color .15s;}
.apply-back:hover{color:var(--accent);}
.apply-back i{font-size:13px;}

.apply-hero{text-align:center;padding:48px 24px 36px;background:var(--bg2);border-bottom:1px solid var(--border);}
.apply-hero-logo{width:68px;height:68px;border-radius:50%;border:1.5px solid var(--accent);overflow:hidden;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;}
.apply-hero-logo img{width:100%;height:100%;object-fit:cover;}
.apply-eyebrow{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;}
.apply-title{font-family:'Cinzel',serif;font-size:22px;letter-spacing:.05em;color:var(--text);margin-bottom:12px;line-height:1.3;}
.apply-sub{font-size:14px;color:var(--text-dim);margin-bottom:10px;}
.apply-sub2{font-size:13px;color:var(--text-muted);line-height:1.7;max-width:480px;margin:0 auto;}
.apply-wa{color:var(--accent);font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:5px;}
.apply-wa:hover{text-decoration:underline;}

.apply-form-wrap{padding:28px 20px;max-width:600px;margin:0 auto;}
.apply-form-card{background:var(--bg2);border:1px solid var(--border);border-radius:18px;padding:30px 26px;}

.apply-row{display:flex;gap:14px;}
.apply-row-2>*{flex:1;}
.apply-field-sm{max-width:160px;}
.apply-phone-row{align-items:flex-end;}
.apply-field-code{width:130px;flex-shrink:0;}
.apply-field-phone{flex:1;}

.req{color:var(--accent);font-size:11px;}

.apply-checks{margin:20px 0 24px;}
.apply-check-label{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text-dim);cursor:pointer;line-height:1.55;}
.apply-check-label input[type="checkbox"]{margin-top:3px;accent-color:var(--accent);width:15px;height:15px;flex-shrink:0;}
.apply-legal-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px;}

.apply-submit-btn{width:100%;font-size:14px;letter-spacing:.08em;padding:15px;}

/* Apply footer */
.apply-footer{background:var(--bg2);border-top:1px solid var(--border);padding:48px 24px 32px;text-align:center;margin-top:8px;}
.apply-footer-logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:24px;}
.apply-footer-logo img{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--accent);object-fit:cover;}
.apply-footer-brand{font-family:'Cinzel',serif;font-size:17px;letter-spacing:.2em;color:var(--text);}

.apply-social-label{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px;}
.apply-social-icons{display:flex;justify-content:center;gap:20px;margin-bottom:44px;}
.apply-social-icons a,.apply-social-link{color:var(--text-dim);font-size:22px;transition:color .15s;text-decoration:none;}
.apply-social-icons a:hover,.apply-social-link:hover{color:var(--accent);}
.apply-social-icons a:hover{color:var(--accent);}

.apply-tiers-section{margin-bottom:44px;}
.apply-tiers-title{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;}
.apply-tiers-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;text-align:left;max-width:800px;margin:0 auto;}
.apply-tier-card{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:20px 18px;position:relative;}
.apply-tier-card.atc-featured{border-color:var(--accent);background:rgba(201,168,76,.06);}
.apply-tier-card.atc-gold{border-color:var(--accent);background:rgba(201,168,76,.1);}
.atc-badge{display:inline-block;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--on-accent);background:var(--accent);border-radius:20px;padding:3px 10px;margin-bottom:10px;font-weight:700;}
.atc-name{font-family:'Cinzel',serif;font-size:13px;letter-spacing:.08em;color:var(--text);margin-bottom:8px;}
.atc-desc{font-size:12px;color:var(--text-dim);line-height:1.6;}

.apply-copyright{font-size:11px;color:var(--text-muted);letter-spacing:.05em;}
.apply-copyright a{color:var(--text-muted);text-decoration:underline;text-underline-offset:2px;}

@media(max-width:480px){
  .apply-form-card{padding:22px 16px;}
  .apply-row-2{flex-direction:column;gap:0;}
  .apply-field-sm{max-width:100%;}
}
