@import"https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;600;700&display=swap";:root{font-family:Noto Sans SC,Microsoft YaHei,sans-serif;color:#102a43;background:#f2f5f7;font-synthesis:none;--navy: #082f54;--navy-deep: #052541;--teal: #078c87;--teal-dark: #066f6b;--muted: #6d7b8c;--line: #e4e9ee}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit}button{cursor:pointer}.language-switcher select{min-height:38px;border:1px solid #d8e2e7;border-radius:8px;background:#fff;color:#24435b;padding:0 12px}.portal-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:#f4f7f8}.portal-page{width:min(100%,410px);min-height:790px;background:#fff;padding:30px 32px 25px;box-shadow:0 12px 36px #19304614;display:flex;flex-direction:column}.topbar-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.brand-lockup{display:flex;gap:12px;align-items:center}.brand-mark{width:48px;height:48px;display:grid;place-items:center;color:var(--teal);border:1px solid #cfe8e6;border-radius:50%;background:#f1fbfa}.brand-logo-image{display:block;width:100%;height:100%;object-fit:contain}.brand-lockup div:last-child{display:flex;flex-direction:column;gap:1px}.brand-lockup strong{font-size:18px;color:#0d2c49}.brand-lockup span{font-size:12px;color:var(--muted)}.storefront-photo{width:100%;height:155px;object-fit:cover;border-radius:9px;margin-top:22px;display:block}.portal-hero{text-align:center;padding:38px 0 25px;border-bottom:1px solid var(--line)}.eyebrow{display:block;color:var(--teal);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.portal-hero h1{margin:8px 0 17px;color:#092b4b;font-size:29px;letter-spacing:-.04em}.network-pill{width:fit-content;margin:0 auto;display:flex;align-items:center;gap:9px;color:#0a5554;font-weight:700;font-size:17px;background:#edf9f7;border-radius:999px;padding:9px 17px}.portal-hero p{font-size:12px;color:var(--muted);margin:15px 0 0}.ad-section{padding:18px 0 0}.section-heading{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#66788a;margin-bottom:8px}.ad-disclosure,.ad-label{border:1px solid #cdd5dd;border-radius:3px;padding:1px 5px;font-size:10px;color:#718092}.ad-preview{min-height:120px;padding:19px 18px;position:relative;background:#f1f7f6;border:1px solid #dcebe9;display:grid;gap:4px;align-items:center;border-radius:8px;overflow:hidden}.ad-preview:after{content:"";position:absolute;width:90px;height:90px;border-radius:50%;background:#d7eeeb;right:-25px;top:-40px;opacity:.65}.ad-label{position:absolute;right:7px;top:7px;z-index:1;background:#fff}.ad-brand{grid-area:brand;font-size:18px;font-weight:700;color:#153b56;align-self:end}.ad-copy{grid-area:copy;color:#698090;font-size:12px;align-self:start;margin-top:3px}.ad-cta{grid-area:cta;position:relative;z-index:2;border:1px solid #078c87;background:#fff;color:#07736f;border-radius:6px;padding:8px 12px;font-size:12px;font-weight:600;margin-right:8px}.store-message{padding:17px 0 14px;text-align:center;display:grid;gap:6px;justify-items:center}.store-message strong{display:block;color:#183650;font-size:13px}.store-message p{margin:0;color:#667a8d;font-size:11px;line-height:1.6}.store-message span{color:#96a1ac;font-size:10px}.menu-link-button{margin-top:6px;min-height:38px;padding:0 16px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a3155,#0b897f);color:#fff;text-decoration:none;font-size:12px;font-weight:700;box-shadow:0 10px 24px #082f5424}.secondary-ad{padding-top:5px}.ad-preview-compact{min-height:76px;padding:14px 15px}.ad-preview-compact>div{display:flex;flex-direction:column;gap:2px}.ad-preview-compact strong{color:#21445d;font-size:13px}.ad-preview-compact small{color:#738698;font-size:10px}.consent-section{padding-top:18px}.consent-row{display:grid;grid-template-columns:24px 1fr;gap:10px;align-items:start;color:#243b53;font-size:13px;line-height:1.65;cursor:pointer}.consent-row input{position:absolute;opacity:0;pointer-events:none}.custom-checkbox{width:23px;height:23px;border:1.5px solid #b7c2cd;border-radius:5px;display:grid;place-items:center;color:#fff;margin-top:1px;transition:.2s}.consent-row input:checked+.custom-checkbox{background:var(--teal);border-color:var(--teal)}.text-button{padding:0 2px;border:0;background:transparent;color:var(--teal-dark);font-weight:600;text-decoration:underline}.consent-note{display:flex;gap:7px;align-items:center;margin:10px 0 15px 34px;color:#738090;font-size:11px}.consent-note svg{color:#20a77a}.connect-button{width:100%;min-height:54px;border:0;border-radius:7px;display:flex;align-items:center;justify-content:center;gap:9px;background:var(--teal);color:#fff;font-size:16px;font-weight:700;transition:.2s}.connect-button:not(:disabled):hover{background:var(--teal-dark);transform:translateY(-1px)}.connect-button:disabled{cursor:not-allowed;background:#c8ced4;color:#f7f8f9}.connect-button.connecting{background:#176b8b}.connect-button.success{background:#16875e}.connect-button.failed{background:#b94b4b}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.success-copy{margin:9px 0 0;text-align:center;color:#16875e;font-size:11px}.wifi-reveal-card{margin-top:14px;border:1px solid #dce8ee;border-radius:10px;background:linear-gradient(180deg,#f9fcfc,#f2f7f7);padding:15px;display:grid;gap:13px}.wifi-reveal-head{display:grid;gap:4px}.wifi-reveal-head strong{color:#10324e;font-size:15px}.wifi-reveal-head span{color:#6f7f90;font-size:11px;line-height:1.6}.wifi-facts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.wifi-facts>div,.wifi-password-box{border-radius:8px;background:#fff;border:1px solid #e2e9ee;padding:11px 12px}.wifi-facts>div{display:grid;gap:4px;align-content:start}.wifi-facts small,.wifi-password-box small{display:block;color:#7d8e9f;font-size:10px;margin-bottom:4px}.wifi-facts strong,.wifi-password-box strong{color:#163650;font-size:14px;word-break:break-all}.wifi-password-box{display:grid;grid-template-columns:1fr auto;gap:9px;align-items:center}.wifi-password-box small,.wifi-password-box strong{grid-column:1 / 2}.wifi-password-box.clickable{width:100%;text-align:left;cursor:pointer}.wifi-password-box.clickable span{color:#0b817b;font-size:11px;font-weight:700}.wifi-password-box.clickable:disabled{cursor:default;opacity:.72}.copy-button,.secondary-connect-button{border:0;border-radius:8px;font-weight:700}.copy-button{grid-column:2 / 3;grid-row:1 / 3;padding:0 12px;min-height:38px;background:#e9f7f5;color:#087d78}.copy-button.inline{grid-column:auto;grid-row:auto;width:fit-content;min-height:34px;padding:0 10px;font-size:11px}.wifi-qr-block{display:grid;justify-items:center;gap:10px;padding:6px 0 2px}.wifi-qr-block img{width:190px;height:190px;border-radius:12px;border:1px solid #dce3e9;background:#fff;padding:8px}.wifi-qr-block p{margin:0;color:#708091;font-size:11px;line-height:1.7;text-align:center}.secondary-connect-button{width:100%;min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#10324e;color:#fff}.secondary-connect-button.ghost{background:#eef3f8;color:#24435b;border:1px solid #d9e2ea}.connection-result-card{margin-top:14px;border:1px solid #dce8ee;border-radius:10px;background:linear-gradient(180deg,#f9fcfc,#f2f7f7);padding:15px;display:grid;gap:10px}.connection-result-card strong{color:#10324e;font-size:15px}.connection-result-card p{margin:0;color:#6f7f90;font-size:11px;line-height:1.7}.connection-helper{color:#8a98a7;font-size:10px;line-height:1.6}.connection-result-card.failed{border-color:#f0d0d0;background:#fff7f7}.connection-result-actions{display:grid;gap:10px}.portal-page footer{margin-top:auto;padding-top:22px;display:flex;justify-content:center;align-items:center;gap:6px;font-size:11px;color:#6d7b8c}.portal-page footer svg{color:#18a779}.scanner-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:#eef5f6}.scanner-page{width:min(100%,430px);min-height:720px;background:#fff;border:1px solid #dfe9ee;border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:18px;box-shadow:0 18px 55px #0f2d431f}.scanner-head{display:grid;grid-template-columns:42px 1fr auto;gap:12px;align-items:start}.scanner-head>span{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:var(--teal);background:#e8f8f6}.scanner-brand-logo{width:28px;height:28px}.scanner-head h1{margin:0;color:#082f54;font-size:24px;line-height:1.2}.scanner-head p{margin:5px 0 0;color:#6d7d8e;font-size:12px;line-height:1.55}.scanner-view{position:relative;aspect-ratio:3 / 4;border-radius:12px;overflow:hidden;background:#082f54;border:1px solid #cfe0e7}.scanner-view video{width:100%;height:100%;object-fit:cover;display:block}.scanner-view i{position:absolute;top:13%;right:13%;bottom:13%;left:13%;border:2px solid rgba(32,212,200,.85);box-shadow:0 0 0 999px #082f5447;border-radius:10px;pointer-events:none}.scanner-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;align-content:center;gap:12px;padding:28px;color:#d9eef1;text-align:center;background:linear-gradient(135deg,#082f54,#104b70)}.scanner-placeholder span{font-size:13px;line-height:1.55}.scanner-result{display:grid;gap:6px;border:1px solid #dfe8ed;border-radius:8px;background:#f8fbfc;padding:12px}.scanner-result small{color:#7d8d9d;font-size:10px;font-weight:700}.scanner-result code{color:#17364f;font-size:11px;word-break:break-all;white-space:pre-wrap}.scanner-warning{display:flex;align-items:center;gap:7px;margin:0;color:#a65d1e;background:#fff8e8;border:1px solid #f0dfbd;border-radius:8px;padding:10px 12px;font-size:12px;line-height:1.45}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#041b2f94;display:grid;place-items:center;z-index:100;padding:20px}.terms-modal{position:relative;width:min(100%,430px);border-radius:15px;background:#fff;padding:32px;box-shadow:0 20px 60px #00000038}.modal-close{position:absolute;right:14px;top:14px;width:34px;height:34px;border:0;border-radius:50%;background:#f1f4f6;color:#5d6b7a;display:grid;place-items:center}.modal-icon{color:var(--teal)}.terms-modal h2{margin:13px 0 14px;font-size:21px;color:#0d2c49}.terms-modal p{color:#5f7182;line-height:1.75;font-size:13px}.modal-confirm{width:100%;margin-top:12px;border:0;border-radius:8px;padding:12px;background:var(--teal);color:#fff;font-weight:700}.admin-shell{min-height:100vh;display:grid;grid-template-columns:220px minmax(0,1fr);background:#f5f7f9}.sidebar{background:var(--navy-deep);color:#fff;padding:28px 14px 20px;display:flex;flex-direction:column;min-height:100vh}.sidebar-brand{display:flex;gap:10px;align-items:center;padding:0 12px 28px}.sidebar-brand-logo{width:30px;height:30px;flex:0 0 30px}.sidebar-brand div{display:flex;flex-direction:column}.sidebar-brand strong{font-size:16px}.sidebar-brand span{font-size:10px;color:#9eb3c7;margin-top:2px}.sidebar nav{display:flex;flex-direction:column;gap:7px}.sidebar nav button{height:45px;padding:0 14px;border:0;border-radius:7px;color:#c8d6e2;background:transparent;display:flex;align-items:center;gap:12px;text-align:left;font-size:14px;transition:.18s}.sidebar nav button:hover{background:#ffffff0f;color:#fff}.sidebar nav button.active{background:#078c87;color:#fff;box-shadow:0 5px 16px #078c8738}.sidebar-user{width:100%;margin-top:auto;border:0;border-top:1px solid rgba(255,255,255,.1);padding:18px 8px 0;display:grid;grid-template-columns:34px 1fr auto;gap:9px;align-items:center;color:#dce5ed;background:transparent;text-align:left}.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#dbe6ed;color:#37556f}.sidebar-user>span:nth-child(2){display:flex;flex-direction:column}.sidebar-user strong{font-size:11px}.sidebar-user small{font-size:9px;color:#8ea5ba}.dashboard{padding:25px 28px 14px;min-width:0}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.dashboard-header h1{margin:3px 0 0;font-size:27px;color:#102d49;letter-spacing:-.03em}.header-actions{display:flex;gap:10px}.header-actions select,.header-actions button,.store-panel input{border:1px solid #dbe2e8;border-radius:7px;background:#fff;color:#405368;height:39px;padding:0 12px;font-size:12px}.header-actions button{display:flex;align-items:center;gap:7px}.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.metric-card{background:#fff;border:1px solid var(--line);border-radius:8px;min-height:118px;padding:18px;display:flex;gap:14px;align-items:center}.metric-icon{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto}.metric-icon.teal{background:#e2f5f3;color:#078c87}.metric-icon.blue{background:#e7f1fb;color:#2477b8}.metric-icon.orange{background:#fff1dd;color:#dc801c}.metric-icon.green{background:#e5f5ed;color:#21865d}.metric-card>div:last-child{display:flex;flex-direction:column}.metric-card span{font-size:12px;color:#66788a}.metric-card strong{font-size:23px;line-height:1.35;letter-spacing:-.02em;color:#102d49}.metric-card small{display:flex;align-items:center;gap:2px;color:#129477;font-size:10px}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.9fr) minmax(290px,.8fr);grid-template-rows:353px;gap:14px;margin-top:14px}.panel{background:#fff;border:1px solid var(--line);border-radius:8px}.panel-heading{min-height:70px;padding:17px 19px 12px;display:flex;justify-content:space-between;align-items:flex-start}.panel-heading h2{margin:0;font-size:15px;color:#193550}.panel-heading p{margin:3px 0 0;color:#8190a0;font-size:10px}.segmented{display:flex;border:1px solid #dbe2e8;border-radius:6px;overflow:hidden}.segmented button{width:41px;height:27px;border:0;border-right:1px solid #dbe2e8;background:#fff;color:#6c7b8b;font-size:11px}.segmented button:last-child{border:0}.segmented button.active{color:#087c78;background:#eaf8f6}.chart-wrap{height:270px;padding:0 14px 10px}.activity-panel{grid-column:2;grid-row:1}.live-dot{width:7px;height:7px;display:inline-block;border-radius:50%;background:#23b380;margin-right:4px}.activity-list{padding:0 16px}.activity-row{min-height:51px;border-top:1px solid #edf0f3;display:grid;grid-template-columns:32px 1fr auto;align-items:center;gap:9px}.activity-icon{width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:#e4f5f2;color:#078c87}.activity-icon.ad{background:#fff0dc;color:#ed8c1e}.activity-row div{display:flex;flex-direction:column}.activity-row strong{font-size:11px;color:#3d5268}.activity-row span{font-size:9px;color:#8a98a7;margin-top:2px}.activity-row time{font-size:9px;color:#8594a3}.store-panel{margin-top:14px}.store-panel input{height:33px;width:180px}.table-scroll{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:670px}th{background:#f8fafb;color:#718091;font-size:10px;font-weight:500;text-align:left;padding:10px 18px;border-top:1px solid #edf0f3;border-bottom:1px solid #edf0f3}td{padding:10px 18px;border-bottom:1px solid #edf0f3;color:#485b6e;font-size:11px}td:first-child{color:#213c55;font-weight:500;display:flex;align-items:center;gap:8px}.store-icon{width:25px;height:25px;display:grid;place-items:center;border-radius:5px;background:#edf7f5;color:#087c78}.status-badge{padding:3px 8px;border-radius:999px;font-size:9px}.status-badge.online{background:#e4f5ed;color:#16875e}.status-badge.maintenance{background:#fff0dc;color:#b86a13}.dashboard-footnote{text-align:right;color:#8c99a6;font-size:9px;margin:9px 2px 0}.store-profile-layout{display:grid;grid-template-columns:265px minmax(0,1fr);gap:14px;align-items:start}.store-directory{overflow:hidden}.directory-head{min-height:74px;padding:17px;border-bottom:1px solid #e7ecef;display:flex;justify-content:space-between;align-items:center}.directory-head h2{margin:0;font-size:15px}.directory-head p{margin:3px 0 0;color:#8a98a6;font-size:10px}.directory-head>button{width:32px;height:32px;display:grid;place-items:center;border:0;border-radius:7px;background:#e8f7f5;color:#078c87}.directory-list{padding:8px;display:flex;flex-direction:column;gap:4px}.directory-list>button{width:100%;min-height:59px;border:0;border-radius:7px;background:transparent;padding:8px;display:grid;grid-template-columns:34px 1fr 8px;gap:9px;align-items:center;text-align:left}.directory-list>button:hover{background:#f5f8fa}.directory-list>button.active{background:#edf8f7}.directory-list>button>span:nth-child(2){min-width:0;display:flex;flex-direction:column}.directory-list strong{color:#29465e;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.directory-list small{margin-top:3px;color:#8a98a6;font-size:9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.directory-list i{width:7px;height:7px;border-radius:50%;background:#e5a53e}.directory-list i.online{background:#1ca476}.store-editor{min-width:0;overflow:hidden}.editor-head{min-height:82px;padding:18px 20px;display:flex;justify-content:space-between;align-items:center}.editor-head h2{margin:4px 0 0;font-size:20px;color:#14344e}.editor-head .primary-action{min-height:38px}.editor-tabs{border-top:1px solid #edf0f2;border-bottom:1px solid #e3e8ec;padding:0 20px;display:flex;gap:24px}.editor-tabs button{height:44px;border:0;border-bottom:2px solid transparent;background:transparent;color:#728293;font-size:11px;font-weight:600}.editor-tabs button.active{color:#087d78;border-bottom-color:#078c87}.editor-head-actions{display:flex;gap:10px;align-items:center}.danger-action{min-height:38px;border:1px solid #f0c6c6;border-radius:7px;background:#fff4f4;color:#b54242;padding:0 14px;font-weight:700}.editor-section{padding:22px}.info-editor{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:20px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;align-content:start}.form-grid label{display:flex;flex-direction:column;gap:6px;color:#53677a;font-size:10px;font-weight:600}.form-grid input,.form-grid select,.form-grid textarea{width:100%;border:1px solid #d9e1e6;border-radius:7px;padding:0 11px;color:#25435b;background:#fff;resize:vertical;outline:none}.form-grid input,.form-grid select{height:42px}.form-grid textarea{padding-top:10px;font-family:inherit}.form-grid .wide{grid-column:1 / -1}.photo-uploader{min-height:215px;border:1.5px dashed #cbd7df;border-radius:9px;background:#f8fafb;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;color:#7e8e9c;overflow:hidden;cursor:pointer}.photo-uploader input,.hidden-upload-input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.photo-uploader img{width:100%;height:215px;object-fit:cover}.photo-uploader svg{color:#078c87}.photo-uploader strong{color:#385168;font-size:11px}.photo-uploader span{font-size:9px}.wifi-editor{display:grid;grid-template-columns:minmax(0,1fr) 265px;gap:24px}.inline-qr{position:relative;min-height:260px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;border-left:1px solid #e5eaed;color:#81909e;text-align:center;padding-left:18px}.inline-qr img{width:180px;height:180px}.inline-qr>svg{color:#a9b6c0}.inline-qr strong{color:#27465f;font-size:12px}.inline-qr p{margin:0;font-size:9px;word-break:break-all}.qr-badge{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 10px;border-radius:999px;background:#e9f7f5;color:#087d78;font-size:10px;font-weight:700}.qr-badge.secondary{background:#eef3f8;color:#516a84}.qr-actions{width:100%;display:grid;gap:8px;margin-top:6px}.qr-actions .secondary-action{width:100%;min-height:38px}.wifi-help-card{border:1px solid #dce6eb;border-radius:9px;background:#f7fbfb;padding:12px}.wifi-help-card strong{display:block;color:#16364e;font-size:11px;margin-bottom:6px}.wifi-help-card p{margin:0 0 6px;color:#607284;font-size:11px;line-height:1.7}.wifi-help-card small{color:#8392a1;font-size:10px;line-height:1.7}.wifi-checklist{border:1px solid #dce6eb;border-radius:9px;background:#fffdf7;padding:12px}.wifi-checklist strong{display:block;color:#16364e;font-size:11px;margin-bottom:8px}.wifi-checklist ul{margin:0;padding-left:18px;color:#607284;font-size:11px;line-height:1.7}.wifi-checklist li+li{margin-top:4px}.qr-stack{display:grid;gap:14px;align-content:start}.ad-mode{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:18px}.ad-mode button{min-height:88px;border:1px solid #dce4e9;border-radius:8px;background:#fff;display:grid;grid-template-columns:38px 1fr;grid-template-rows:auto auto;text-align:left;align-items:center;padding:14px;color:#708193}.ad-mode button.selected{border:2px solid #078c87;background:#f1faf9;padding:13px}.ad-mode svg{grid-row:1 / 3;color:#078c87}.ad-mode strong{color:#24435b;font-size:11px}.ad-mode small{font-size:9px}.ads-surface-section+.ads-surface-section{margin-top:28px;padding-top:22px;border-top:1px solid #e8edf1}.section-heading-block{display:grid;gap:4px;margin-bottom:14px}.section-heading-block strong{color:#17364f;font-size:14px}.section-heading-block span{color:#7a8b9b;font-size:11px;line-height:1.6}.ad-placement-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.placement-editor{display:grid;gap:12px;align-content:start}.placement-upload{min-height:205px;border:1.5px dashed #c9d5dd;border-radius:9px;background:#f8fafb;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;overflow:hidden;color:#8292a0;position:relative;padding:14px;text-align:center}.placement-upload svg{color:#078c87}.placement-upload strong{color:#304e65;font-size:11px}.placement-upload span,.placement-upload small{font-size:9px}.placement-upload img,.placement-upload video{width:100%;height:145px;object-fit:contain;background:#edf1f3;border-radius:8px}.upload-trigger{align-self:center}.ad-config-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ad-config-fields label{display:flex;flex-direction:column;gap:6px;color:#53677a;font-size:10px;font-weight:600}.ad-config-fields input,.ad-config-fields textarea{width:100%;border:1px solid #d9e1e6;border-radius:7px;padding:10px 11px;color:#25435b;background:#fff;resize:vertical;outline:none}.ad-config-fields input[type=range]{padding:0}.ad-config-fields .wide{grid-column:1 / -1}.ad-preview-card{border:1px solid #e1e8ee;border-radius:10px;background:#f8fafb;padding:12px;display:grid;gap:10px}.custom-ad-link{display:block;text-decoration:none;color:inherit}.custom-ad-card{position:relative;min-height:150px;border-radius:10px;overflow:hidden;background:#eff4f7;border:1px solid #dbe3e9}.custom-ad-card.compact{min-height:92px}.custom-ad-card.preview-top{min-height:0;aspect-ratio:16 / 9}.custom-ad-card.preview-bottom{min-height:0;aspect-ratio:3 / 1}.custom-ad-media-frame{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.custom-ad-media{width:100%;height:100%;object-fit:cover;display:block;transform-origin:center center;pointer-events:none}.custom-ad-overlay{position:absolute;inset:auto 0 0 0;padding:14px;display:grid;gap:4px;background:linear-gradient(180deg,#082f5400,#082f54c2);color:#fff;z-index:1;pointer-events:none}.custom-ad-overlay strong{font-size:15px;line-height:1.3}.custom-ad-overlay span{font-size:11px;line-height:1.55;opacity:.95}.empty-ad-preview{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#95a4b1;font-size:12px}.preview-draggable.is-ready{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.preview-draggable.is-ready:active{cursor:grabbing}.drag-tip{position:absolute;top:10px;right:10px;z-index:2;padding:4px 8px;border-radius:999px;background:#082f549e;color:#fff;font-size:10px;pointer-events:none}.editor-message{margin:0 22px 20px;border-radius:7px;padding:9px 11px;background:#eaf7f1;color:#16845f;font-size:10px}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:#f2f6f7}.login-card{width:min(100%,410px);background:#fff;border:1px solid #e2e8ed;border-radius:14px;padding:34px;box-shadow:0 18px 55px #0f2d431a}.login-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.login-brand{display:flex;align-items:center;gap:11px;padding-bottom:27px;border-bottom:1px solid #e8edef}.login-brand>span{width:45px;height:45px;display:grid;place-items:center;border-radius:50%;background:#eaf8f6;color:var(--teal)}.login-brand div{display:flex;flex-direction:column}.login-brand strong{color:#0b2e4d;font-size:17px}.login-brand small{color:#8090a0;font-size:10px}.login-heading{margin:28px 0 22px}.login-heading h1{margin:0;font-size:25px;color:#0d2c49}.login-heading p{margin:5px 0 0;color:#8090a0;font-size:12px}.login-card label{display:flex;flex-direction:column;gap:7px;margin-top:16px;color:#42566a;font-size:12px;font-weight:600}.login-card input,.setup-form input,.setup-form select{height:44px;border:1px solid #d8e0e6;border-radius:7px;padding:0 12px;color:#18364f;background:#fff;outline:none}.login-card input:focus,.setup-form input:focus,.setup-form select:focus{border-color:#078c87;box-shadow:0 0 0 3px #078c871a}.login-card>button{width:100%;height:46px;margin-top:22px;border:0;border-radius:7px;background:var(--teal);color:#fff;font-weight:700}.login-error{color:#c33e3e;background:#fff0f0;border-radius:6px;padding:8px 10px;font-size:11px}.login-security{display:flex;align-items:center;justify-content:center;gap:5px;color:#8a98a6;font-size:10px;margin:17px 0 0}.login-security svg{color:#1a9d75}.live-label{color:#087c78;background:#e8f7f5;padding:5px 10px;border-radius:999px;font-size:10px}.management-layout{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(280px,.7fr);gap:14px}.setup-panel{min-width:0}.setup-form{padding:0 19px 22px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.setup-form label{display:flex;flex-direction:column;gap:6px;color:#516477;font-size:11px;font-weight:600}.setup-form .primary-action{grid-column:1 / -1}.primary-action,.secondary-action{min-height:42px;border:0;border-radius:7px;background:var(--teal);color:#fff;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;gap:7px;font-weight:700;font-size:12px}.secondary-action{background:#eaf7f5;color:#087c78;border:1px solid #cfe8e5}.qr-panel{display:flex;flex-direction:column;align-items:center;padding-bottom:22px;text-align:center}.qr-panel .panel-heading{width:100%}.qr-panel img{width:190px;height:190px;border:1px solid #e2e8ec;border-radius:9px}.qr-panel>strong{font-size:13px;margin-top:10px}.qr-panel>p{font-size:10px;color:#7d8b99;max-width:230px;word-break:break-all}.qr-empty{min-height:215px;display:grid;place-items:center;align-content:center;gap:9px;color:#a0adb8}.qr-empty p{margin:0;font-size:11px}.integration-note{grid-column:1 / -1;display:flex;gap:14px;padding:19px;align-items:flex-start;background:#f1f8f7;border-color:#d8e9e7}.integration-note svg{color:var(--teal);flex:0 0 auto}.integration-note h3{margin:0 0 5px;font-size:13px}.integration-note p{margin:0;color:#66788a;font-size:11px;line-height:1.7}.management-layout>.store-panel{grid-column:1 / -1;margin-top:0}.custom-ad-media{width:100%;min-height:120px;max-height:210px;object-fit:cover;border-radius:8px;display:block}.ad-manager{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.7fr);gap:14px}.ad-manager>.panel{min-width:0}.ad-source-grid{padding:0 19px 22px;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.ad-source-grid>button{position:relative;min-height:150px;border:1px solid #dfe6eb;border-radius:9px;background:#fff;display:flex;flex-direction:column;align-items:flex-start;gap:7px;padding:20px;color:#65778a;text-align:left}.ad-source-grid>button.selected{border:2px solid #078c87;background:#f2fbfa;padding:19px}.ad-source-grid>button>span{width:42px;height:42px;border-radius:9px;display:grid;place-items:center;background:#edf7f6;color:var(--teal)}.ad-source-grid strong{color:#18364f;font-size:13px}.ad-source-grid small{font-size:10px;line-height:1.5}.ad-source-grid>button>svg:last-child{position:absolute;top:12px;right:12px;color:var(--teal)}.upload-panel{padding-bottom:22px}.upload-drop{margin:0 19px;min-height:250px;border:1.5px dashed #cbd7df;border-radius:9px;background:#f8fafb;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#789;cursor:pointer;overflow:hidden}.upload-drop input{position:absolute;opacity:0;pointer-events:none}.upload-drop>svg{color:var(--teal)}.upload-drop strong{color:#314b62;font-size:12px}.upload-drop span{font-size:10px}.upload-drop img,.upload-drop video{width:100%;height:185px;object-fit:contain;background:#eef2f4}.save-ad{margin:16px 19px 0;width:calc(100% - 38px)}.save-message{color:#16875e;font-size:10px;text-align:center}.system-panel{max-width:1000px}.sync-steps{padding:0 19px 22px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.sync-steps>div{border-top:2px solid #0b8d88;padding-top:13px}.sync-steps span{display:grid;place-items:center;width:25px;height:25px;border-radius:50%;background:#e6f6f4;color:#087c78;font-size:11px;font-weight:700}.sync-steps h3{margin:10px 0 4px;font-size:12px}.sync-steps p{margin:0;color:#728293;font-size:10px;line-height:1.65}.security-callout{margin:0 19px 22px;background:#fff7e9;border:1px solid #f0dfbf;border-radius:8px;padding:14px;display:flex;gap:10px;color:#9b6a20}.security-callout p{margin:0;font-size:10px;line-height:1.65}@media(max-width:1050px){.metrics-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr;grid-template-rows:340px auto}.activity-panel{grid-column:1;grid-row:2}.ad-manager{grid-template-columns:1fr}.sync-steps{grid-template-columns:repeat(2,1fr)}.store-profile-layout{grid-template-columns:220px minmax(0,1fr)}.info-editor,.wifi-editor{grid-template-columns:1fr}.inline-qr{border-left:0;border-top:1px solid #e5eaed;padding-top:20px}.ad-config-fields{grid-template-columns:1fr}}@media(max-width:720px){.portal-shell{padding:0;align-items:start}.portal-page{width:100%;min-height:100vh;box-shadow:none;padding:25px 24px 20px}.topbar-row{align-items:center}.wifi-facts,.wifi-password-box{grid-template-columns:1fr}.wifi-password-box small,.wifi-password-box strong,.copy-button{grid-column:auto;grid-row:auto}.admin-shell{display:block}.sidebar{min-height:auto;padding:16px;flex-direction:row;align-items:center;overflow-x:auto}.sidebar-brand{padding:0 18px 0 0;min-width:165px}.sidebar nav{flex-direction:row}.sidebar nav button{white-space:nowrap}.sidebar-user{display:none}.dashboard{padding:20px 16px 70px}.dashboard-header{align-items:flex-start}.header-actions select{display:none}.metrics-grid{grid-template-columns:1fr}.metric-card{min-height:90px}.dashboard-grid{grid-template-rows:325px auto}.panel-heading{min-height:66px}.store-panel input{width:130px}.management-layout,.setup-form{grid-template-columns:1fr}.setup-form .primary-action{grid-column:1}.integration-note,.management-layout>.store-panel{grid-column:1}.ad-source-grid,.sync-steps,.store-profile-layout{grid-template-columns:1fr}.directory-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.editor-head{align-items:flex-start;gap:10px;flex-direction:column}.editor-head .primary-action{padding:0 10px}.editor-head-actions{width:100%;display:grid;grid-template-columns:1fr 1fr}.editor-tabs{overflow-x:auto}.editor-tabs button{white-space:nowrap}.form-grid,.ad-mode,.ad-placement-grid{grid-template-columns:1fr}.form-grid .wide{grid-column:1}.info-editor{grid-template-columns:1fr}}
