@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";.portal-shell{color:#17243a;background:radial-gradient(circle at 50% 0,#eaf3ff,#f5f8fc 45%,#eef3f8);place-items:center;min-height:100vh;padding:22px;display:grid}.phone-app{background:#f8faff;border:1px solid #fff;border-radius:32px;width:390px;height:min(844px,100vh - 44px);position:relative;overflow:hidden;box-shadow:0 18px 60px #5870962b}.back-admin{color:#306dce;z-index:30;background:#fff;border:1px solid #d8e2f0;border-radius:12px;padding:10px 14px;font-size:11px;font-weight:700;position:fixed;top:22px;left:22px}.mobile-page{scrollbar-width:none;background:#f8faff;position:absolute;inset:0 0 70px;overflow-y:auto}.mobile-page::-webkit-scrollbar{display:none}.home-head{align-items:center;gap:12px;height:100px;padding:0 3px;display:flex}.customer-avatar,.large-avatar{color:#fff;background:linear-gradient(135deg,#c9a080,#6a3e30);border:3px solid #fff;border-radius:50%;place-items:center;width:47px;height:47px;font-size:11px;font-weight:800;display:grid;box-shadow:0 4px 12px #6a3e3033}.home-head>div:nth-child(2){flex:1}.home-head small{color:#8190a6;font-size:10px}.home-head h2{margin:2px 0 7px;font-size:18px}.home-head span,.profile-hero>span{color:#66748b;background:#eef2f8;border-radius:20px;padding:5px 8px;font-size:8px;display:inline-block}.home-head button{background:0 0;border:0;font-size:23px;position:relative}.home-head em{color:#fff;background:#ec5563;border-radius:50%;place-items:center;width:15px;height:15px;font-size:7px;font-style:normal;display:grid;position:absolute;top:-5px;right:-2px}.blue-promo{color:#fff;background:linear-gradient(135deg,#347ee9,#5e9af5);border-radius:17px;height:168px;padding:20px;position:relative;overflow:hidden;box-shadow:0 12px 28px #357be933}.blue-promo:after{content:"";background:#ffffff15;border:1px solid #ffffff1f;border-radius:50%;width:140px;height:140px;position:absolute;bottom:-40px;right:-10px}.blue-promo small{color:#dceaff;font-size:9px}.blue-promo h1{margin:10px 0 16px;font-size:20px;line-height:1.3}.blue-promo button{color:#2168d6;background:#fff;border:0;border-radius:10px;padding:10px 14px;font-size:9px}.promo-tooth{filter:drop-shadow(0 10px 12px #1d57a555);font-size:65px;position:absolute;top:48px;right:28px}.promo-tooth b{color:#3e82e8;background:#fff;border-radius:50%;place-items:center;width:39px;height:39px;font-size:22px;display:grid;position:absolute;bottom:-5px;right:-10px}.section-title{justify-content:space-between;align-items:center;margin:22px 2px 11px;display:flex}.section-title b{font-size:12px}.section-title button{color:#1d70eb;background:0 0;border:0;font-size:9px}.next-appointment{text-align:left;background:#fff;border:0;border-radius:15px;grid-template-columns:53px 1fr auto;align-items:center;gap:10px;width:100%;padding:12px;display:grid;box-shadow:0 5px 18px #6d7f9a12}.date-badge{color:#216fde;background:#edf4ff;border-radius:12px;place-items:center;width:53px;height:58px;padding:7px;display:grid}.date-badge b{font-size:21px;line-height:1}.date-badge small{font-size:7px}.next-appointment>div:nth-child(2) b,.next-appointment>div:nth-child(2) small{font-size:11px;display:block}.next-appointment>div:nth-child(2) small{color:#8290a4;margin-top:6px;font-size:8px}.m-status{white-space:nowrap;border-radius:20px;padding:6px 8px;font-size:7px;display:inline-block}.m-đã-xác-nhận,.m-hoàn-thành{color:#269665;background:#dcf5e9}.m-chờ-xác-nhận{color:#cf8221;background:#fff1d8}.m-đã-hủy{color:#d95760;background:#ffe5e7}.quick-services{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.quick-services button{color:#fff;background:linear-gradient(160deg,#69a7fa,#347be6);border:0;border-radius:13px;flex-direction:column;justify-content:center;align-items:center;gap:7px;height:90px;padding:10px 4px;display:flex;box-shadow:0 8px 17px #2f75dc25}.quick-services i{font-size:25px;font-style:normal}.quick-services span{font-size:7px;line-height:1.25}.points-card{color:#fff;background:linear-gradient(135deg,#2875e8,#69a4f7);border-radius:13px;height:72px;margin-top:17px;padding:15px;position:relative;overflow:hidden}.points-card small,.points-card b{font-size:8px;display:block}.points-card b{margin-top:7px;font-size:16px}.points-card span{font-size:38px;position:absolute;top:16px;right:20px}.empty-book{color:#2971dd;background:#edf5ff;border:1px dashed #82acec;border-radius:14px;width:100%;padding:20px}.mobile-bottom-nav{z-index:8;background:#fff;border-top:1px solid #e4eaf3;grid-template-columns:repeat(4,1fr);height:70px;padding-bottom:5px;display:grid;position:absolute;bottom:0;left:0;right:0}.mobile-bottom-nav button{color:#8390a2;background:0 0;border:0;flex-direction:column;justify-content:center;align-items:center;gap:3px;display:flex}.mobile-bottom-nav span{font-size:20px;line-height:1}.mobile-bottom-nav small{font-size:7px}.mobile-bottom-nav button.active{color:#1670ed;font-weight:700}.mobile-topbar{text-align:center;z-index:5;background:#fff;border-bottom:1px solid #e6ebf3;grid-template-columns:45px 1fr 45px;align-items:center;height:66px;display:grid;position:sticky;top:0}.mobile-topbar b{font-size:14px}.mobile-topbar button{color:#17243a;background:0 0;border:0;font-size:25px}.with-header{padding:0}.segment{background:#fff;border-bottom:1px solid #e9edf4;grid-template-columns:1fr 1fr;height:53px;display:grid}.segment button{color:#8a96a8;background:0 0;border:0;border-bottom:2px solid #0000;font-size:10px}.segment button.active{color:#1d70eb;border-color:#1d70eb;font-weight:700}.appointment-content h3,.health-content h3{margin:3px 2px 12px;font-size:12px}.appointment-card{text-align:left;background:#fff;border:0;border-radius:14px;grid-template-columns:53px 1fr auto;gap:10px;width:100%;margin-bottom:11px;padding:11px;display:grid;position:relative;overflow:hidden;box-shadow:0 4px 16px #68799212}.appointment-card .appointment-info b,.appointment-card .appointment-info small{font-size:10px;display:block}.appointment-card .appointment-info small{color:#7d899c;margin-top:6px;font-size:8px}.appointment-card .card-detail{text-align:center;color:#176feb;border-top:1px solid #e8edf4;grid-row:2;margin-top:5px;padding-top:11px;font-size:8px}.appointment-card .card-detail:nth-last-child(2){grid-column:1/3}.appointment-card .card-detail:last-child{grid-column:3}.mobile-empty{text-align:center;color:#8996a8;padding:50px 20px;font-size:10px}.mobile-search{color:#7e8ca0;background:#fff;border-radius:22px;align-items:center;gap:8px;height:42px;padding:0 13px;display:flex;box-shadow:0 3px 12px #6d7e9510}.mobile-search input{background:0 0;border:0;outline:0;width:100%;font-size:9px}.category-scroll{scrollbar-width:none;gap:5px;margin:14px -2px;padding:0 2px;display:flex;overflow:auto}.category-scroll button{color:#68758a;white-space:nowrap;background:0 0;border:0;border-radius:15px;padding:8px 12px;font-size:8px}.category-scroll button.active{color:#fff;background:#2875e8}.service-card{text-align:left;background:#fff;border:0;border-radius:14px;grid-template-columns:76px 1fr 15px;align-items:center;gap:11px;width:100%;margin-bottom:10px;padding:9px;display:grid;box-shadow:0 4px 15px #65789414}.service-card>i{background:linear-gradient(135deg,#bde8fa,#4f9aed);border-radius:12px;place-items:center;height:76px;font-size:36px;font-style:normal;display:grid}.service-card b,.service-card small,.service-card strong{display:block}.service-card b{font-size:10px}.service-card small{color:#7f8ca0;margin:5px 0;font-size:7px;line-height:1.45}.service-card strong{color:#1d70eb;font-size:10px}.service-card>span{font-size:20px}.detail-card{background:#fff;border-radius:15px;padding:12px;box-shadow:0 4px 18px #697b9515}.detail-heading{justify-content:space-between;align-items:start;display:flex}.detail-card h2{margin:17px 0 9px;font-size:14px}.detail-card dl{margin:0}.detail-card dl>div{border-top:1px solid #e7edf5;grid-template-columns:85px 1fr;align-items:center;padding:12px 0;display:grid}.detail-card dt{color:#8b97a8;font-size:8px}.detail-card dd{margin:0;font-size:9px;line-height:1.5}.detail-card dd small{color:#8793a5;font-size:7px}.tiny-avatar{color:#2170df;background:#dcecff;border-radius:50%;place-items:center;width:28px;height:28px;margin-right:8px;font-size:7px;display:inline-grid}.detail-actions{grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;display:grid}.detail-actions button{color:#1d70e8;background:#edf4ff;border:0;border-radius:9px;padding:11px;font-size:8px}.detail-actions button:last-child{color:#dd5961;background:#ffe8e9}.support-card{background:linear-gradient(135deg,#f2f7ff,#e5efff);border-radius:14px;justify-content:space-between;align-items:center;margin-top:14px;padding:15px;display:flex}.support-card b,.support-card small,.support-card strong{display:block}.support-card b{font-size:10px}.support-card small{color:#8995a7;margin:7px 0;font-size:7px}.support-card strong{color:#1b70e9;font-size:11px}.support-card button{color:#fff;background:#2d79ea;border:0;border-radius:14px;width:43px;height:43px;font-size:20px;box-shadow:0 8px 15px #2470db33}.profile-hero{color:#fff;background:linear-gradient(140deg,#347ce8,#5b9bf5);height:218px;padding:18px 18px 0;position:relative;overflow:hidden}.profile-hero:after{content:"";background:#ffffff0a;border:1px solid #ffffff0e;border-radius:50%;width:390px;height:170px;position:absolute;bottom:-100px;left:0}.profile-actions{justify-content:space-between;align-items:center;display:flex}.profile-actions b{font-size:15px}.profile-actions button{color:#fff;background:0 0;border:0;font-size:18px}.profile-person{align-items:center;gap:13px;margin-top:28px;display:flex}.large-avatar{background:linear-gradient(135deg,#d3a37d,#694032);width:72px;height:72px;font-size:15px}.profile-person h2,.profile-person p{margin:0}.profile-person h2{font-size:16px}.profile-person p{margin:7px 0;font-size:9px}.profile-person small{font-size:8px}.profile-hero>span{color:#6c7890;background:#fff;margin-top:14px}.profile-menu{background:#fff;border-radius:15px 15px 0 0;margin-top:-12px;padding:8px 15px;position:relative}.profile-menu button{text-align:left;background:0 0;border:0;border-bottom:1px solid #e8edf4;grid-template-columns:25px 1fr 15px;align-items:center;width:100%;height:52px;display:grid}.profile-menu i{color:#1e72ec;font-size:16px;font-style:normal}.profile-menu b{font-size:10px;font-weight:500}.profile-menu span{color:#8090a3;font-size:18px}.health-summary,.health-history{background:#fff;border-radius:14px;margin-bottom:22px;padding:4px 12px;box-shadow:0 4px 15px #61758f12}.health-summary>div{border-bottom:1px solid #e9edf3;grid-template-columns:35px 1fr auto;align-items:center;height:58px;display:grid}.health-summary>div:last-child{border:0}.health-summary i{color:#2172e8;background:#edf4ff;border-radius:8px;place-items:center;width:27px;height:27px;font-style:normal;display:grid}.health-summary b,.health-summary small,.health-summary strong{font-size:8px;display:block}.health-summary small{color:#8090a3;margin-top:4px}.health-summary strong{margin-top:4px;font-size:10px}.health-summary em{color:#8d99a9;font-size:6px;font-style:normal}.health-history>div{border-bottom:1px solid #e8edf3;grid-template-columns:16px 1fr auto;align-items:center;min-height:70px;display:grid}.health-history>div:last-child{border:0}.health-history i{background:#2d7aeb;border:2px solid #dceaff;border-radius:50%;width:7px;height:7px}.health-history b,.health-history small{font-size:8px;display:block}.health-history small{color:#8693a6;margin:3px 0;font-size:6px}.health-history button{color:#1b70e8;background:0 0;border:0;font-size:6px}.health-note{background:linear-gradient(135deg,#edf5ff,#dcecff);border-radius:14px;align-items:center;padding:14px;display:flex}.health-note div{flex:1}.health-note b{font-size:9px}.health-note p{color:#63738a;font-size:7px;line-height:1.5}.health-note span{font-size:42px}.sheet-backdrop{z-index:20;background:#14243b88;align-items:end;display:flex;position:absolute;inset:0}.booking-sheet{background:#fff;border-radius:24px 24px 0 0;width:100%;padding:10px 20px 22px;box-shadow:0 -20px 45px #14243b22}.sheet-handle{background:#d9e1ec;border-radius:5px;width:38px;height:4px;margin:0 auto 13px}.sheet-title{justify-content:space-between;align-items:start;margin-bottom:16px;display:flex}.sheet-title small{color:#2a73df;font-size:7px}.sheet-title h2{margin:4px 0;font-size:17px}.sheet-title button{background:#eef3f9;border:0;border-radius:50%;width:28px;height:28px}.booking-sheet label{color:#718096;margin-bottom:11px;font-size:8px;display:block}.booking-sheet input,.booking-sheet select{background:#fff;border:1px solid #dce5f0;border-radius:9px;width:100%;margin-top:5px;padding:10px;font-size:9px;display:block}.sheet-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.sheet-submit{color:#fff;background:#2876e8;border:0;border-radius:10px;width:100%;padding:12px;font-size:10px;font-weight:700}.toast{z-index:50}@media (width<=600px){.portal-shell{background:#f8faff;width:100%;padding:0;display:block;overflow:hidden}.phone-app{border:0;border-radius:0;width:100%;min-width:0;max-width:100vw;height:100vh}.home-page{width:100%;overflow-x:hidden}.quick-services{grid-template-columns:repeat(4,minmax(0,1fr));gap:7px}.quick-services button{min-width:0}.quick-services span{font-size:6px}.back-admin{opacity:.2;padding:7px;font-size:0;top:8px;left:auto;right:8px}.back-admin:after{content:"A";font-size:8px}.mobile-page{inset:0 0 68px}.mobile-bottom-nav{width:100%}}.phone-app svg{stroke-width:1.8px;width:17px;height:17px}.home-head span,.profile-hero>span{align-items:center;gap:4px;display:inline-flex}.home-head span svg,.profile-hero>span svg{width:10px;height:10px}.home-head button svg{width:22px;height:22px}.blue-promo img{object-fit:cover;mix-blend-mode:screen;opacity:.9;border-radius:50%;width:138px;height:138px;position:absolute;bottom:-18px;right:-12px}.section-title button{align-items:center;gap:1px;display:flex}.section-title button svg{width:10px;height:10px}.quick-services button{color:#263b5a;background:#fff;border:1px solid #e5edf8;padding:6px;box-shadow:0 6px 18px #416fa21a}.quick-services img{object-fit:cover;border-radius:9px;width:100%;height:56px}.quick-services span{place-items:center;height:18px;font-weight:700;display:grid}.points-card{text-align:left;border:0;width:100%}.points-card svg{color:#fff;width:35px;height:35px;position:absolute;top:18px;right:20px}.mobile-bottom-nav svg{width:20px;height:20px}.mobile-topbar svg{width:19px;height:19px}.appointment-info small{align-items:center;gap:4px;display:flex!important}.appointment-info small svg{width:10px;height:10px}.card-detail{justify-content:center;align-items:center;gap:4px;display:flex}.card-detail svg{width:10px;height:10px}.mobile-search svg{width:15px;height:15px}.result-count{color:#8492a6;margin:4px 2px 10px;font-size:8px}.service-card{grid-template-columns:76px 1fr 17px}.service-card>img{object-fit:cover;border-radius:12px;width:76px;height:76px}.service-card>div em{color:#2471df;background:#e7f1ff;border-radius:10px;margin-bottom:4px;padding:3px 6px;font-size:6px;font-style:normal;display:inline-block}.service-card>svg{width:16px;height:16px}.detail-card dt{align-items:center;gap:5px;display:flex}.detail-card dt svg{color:#2874e5;width:11px;height:11px}.support-card button{place-items:center;display:grid}.support-card button svg{width:20px;height:20px}.profile-actions button svg{color:#fff}.profile-menu i{background:#edf4ff;border-radius:8px;place-items:center;width:28px;height:28px;display:grid}.profile-menu button>svg{color:#8491a4;width:15px;height:15px}.health-summary i svg{width:14px;height:14px}.health-history strong{color:#1d70e8;font-size:7px}.health-note>svg{color:#4b8dec;width:42px;height:42px}.subpage-content{padding:16px 12px 28px}.subpage-content h3{margin:22px 2px 10px;font-size:11px}.identity-card{color:#fff;background:linear-gradient(135deg,#327be9,#65a3f5);border-radius:16px;align-items:center;gap:13px;padding:18px;display:flex;box-shadow:0 12px 25px #327bea26}.identity-card b,.identity-card small{font-size:11px;display:block}.identity-card small{color:#e1edff;margin-top:5px;font-size:7px}.form-card{background:#fff;border-radius:14px;margin:12px 0;padding:5px 14px;box-shadow:0 5px 18px #63779612}.form-card label{color:#8491a4;border-bottom:1px solid #edf1f6;padding:10px 0;font-size:7px;display:block}.form-card input{color:#263951;background:0 0;border:0;outline:0;width:100%;margin-top:5px;font-size:10px;display:block}.form-card input:disabled{opacity:1}.primary-action{color:#fff;background:#2876e8;border:0;border-radius:11px;width:100%;padding:13px;font-size:9px;font-weight:700}.mini-stats{grid-template-columns:1fr 1fr;gap:9px;margin-bottom:13px;display:grid}.mini-stats div{background:#fff;border-radius:13px;padding:15px;box-shadow:0 4px 15px #62759012}.mini-stats b,.mini-stats small{display:block}.mini-stats b{color:#2170e2;font-size:16px}.mini-stats small{color:#8794a6;margin-top:5px;font-size:7px}.balance-card{color:#fff;background:linear-gradient(135deg,#1e65d2,#579af3);border-radius:17px;padding:22px;box-shadow:0 13px 27px #256dd133}.balance-card small,.balance-card b{display:block}.balance-card small{color:#dceaff;font-size:8px}.balance-card b{margin:7px 0 15px;font-size:25px}.balance-card button{color:#226bd8;background:#fff;border:0;border-radius:9px;padding:9px 12px;font-size:8px}.invoice-row,.support-link{text-align:left;color:#273a55;background:#fff;border:0;border-radius:13px;grid-template-columns:28px 1fr auto;align-items:center;width:100%;margin-bottom:9px;padding:13px;text-decoration:none;display:grid;box-shadow:0 4px 14px #65779112}.invoice-row>svg,.support-link>svg{color:#2875e7}.invoice-row span b,.invoice-row span small,.support-link span b,.support-link span small{font-size:8px;display:block}.invoice-row span small,.support-link span small{color:#8b97a8;margin-top:4px;font-size:6px}.invoice-row strong{font-size:8px}.reward-hero{color:#fff;text-align:center;background:linear-gradient(140deg,#3079e7,#65a3f4);border-radius:18px;flex-direction:column;align-items:center;height:180px;padding:22px;display:flex;box-shadow:0 14px 30px #2870dc32}.reward-hero>svg{width:38px;height:38px}.reward-hero small{margin-top:10px;font-size:8px}.reward-hero b{margin:5px;font-size:32px}.reward-hero span{color:#e0ecff;font-size:7px}.coupon{background:#fff;border-radius:13px;grid-template-columns:30px 1fr auto;align-items:center;margin-bottom:9px;padding:12px;display:grid;box-shadow:0 4px 15px #63758e12}.coupon>svg{color:#2b77e7}.coupon b,.coupon small{font-size:8px;display:block}.coupon small{color:#8995a7;margin-top:4px;font-size:6px}.coupon button{color:#2671df;background:#edf4ff;border:0;border-radius:8px;padding:7px;font-size:7px}.settings-list>button{text-align:left;background:#fff;border:0;border-bottom:1px solid #e9eef5;grid-template-columns:30px 1fr auto;align-items:center;width:100%;padding:14px;display:grid}.settings-list>button:first-child{border-radius:14px 14px 0 0}.settings-list>button:last-child{border-radius:0 0 14px 14px}.settings-list>button>svg{color:#2976e7}.settings-list span b,.settings-list span small{font-size:8px;display:block}.settings-list span small{color:#8995a6;margin-top:4px;font-size:6px}.toggle{background:#dce3ed;border-radius:20px;align-items:center;width:32px;height:18px;padding:2px;display:flex}.toggle em{background:#fff;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 4px #33465b33}.toggle.on{background:#2876e8;justify-content:flex-end}.support-hero{text-align:center;padding:26px 15px}.support-hero>svg{color:#2876e8;width:42px;height:42px}.support-hero h2{margin:12px 0 5px;font-size:15px}.support-hero p{color:#8190a3;font-size:8px}.mobile-empty{flex-direction:column;align-items:center;gap:8px;display:flex}.mobile-empty svg{color:#91a6c2;width:34px;height:34px}.mobile-empty b{font-size:9px}.promo-slider{border-radius:17px;height:168px;position:relative;overflow:hidden;box-shadow:0 12px 28px #357be92b}.promo-track{height:100%;transition:transform .55s cubic-bezier(.22,.8,.25,1);display:flex}.promo-slide{color:#fff;text-align:left;border:0;flex:none;width:100%;height:100%;padding:21px;position:relative;overflow:hidden}.promo-slide:after{content:"";background:#ffffff13;border:1px solid #ffffff20;border-radius:50%;width:145px;height:145px;position:absolute;bottom:-45px;right:-25px}.promo-slide>div{z-index:2;width:210px;position:relative}.promo-slide small{letter-spacing:.7px;color:#e0edff;font-size:7px}.promo-slide h1{margin:10px 0 5px;font-size:20px;line-height:1.18}.promo-slide p{color:#edf4ff;margin:0 0 13px;font-size:8px}.promo-slide span{color:#256edb;background:#fff;border-radius:9px;align-items:center;gap:3px;padding:8px 10px;font-size:7px;font-weight:700;display:inline-flex}.promo-slide span svg{width:10px;height:10px}.promo-slide img{object-fit:cover;mix-blend-mode:screen;opacity:.94;border-radius:50%;width:130px;height:130px;position:absolute;bottom:-15px;right:-3px}.promo-dots{z-index:3;gap:4px;display:flex;position:absolute;bottom:9px;left:21px}.promo-dots button{background:#fff6;border:0;border-radius:6px;width:5px;height:5px;padding:0;transition:all .3s}.promo-dots button.active{background:#fff;width:17px}.promotion-article{padding-bottom:25px}.article-hero{color:#fff;height:220px;padding:25px;position:relative;overflow:hidden}.article-hero.lime{background:linear-gradient(135deg,#63a932,#a8cf45)}.article-hero>div{z-index:2;width:220px;position:relative}.article-hero small{letter-spacing:1px;color:#e4eeff;font-size:7px}.article-hero h1{margin:12px 0 7px;font-size:24px;line-height:1.15}.article-hero p{color:#eef5ff;font-size:9px;line-height:1.5}.article-hero img{object-fit:cover;mix-blend-mode:screen;border-radius:50%;width:160px;height:160px;position:absolute;bottom:-25px;right:-20px}.promotion-article article{padding:18px}.article-expiry{color:#2471df;background:#edf4ff;border-radius:15px;align-items:center;gap:5px;padding:6px 9px;font-size:7px;display:inline-flex}.article-expiry svg{width:11px;height:11px}.promotion-article article h2{margin:16px 0 8px;font-size:15px;line-height:1.35}.promotion-article article h3{margin:19px 0 9px;font-size:10px}.promotion-article article p{color:#6e7d92;font-size:8px;line-height:1.7}.promotion-article article ul{margin:0;padding:0;list-style:none}.promotion-article article li{background:#fff;border-radius:10px;align-items:center;gap:8px;margin-bottom:6px;padding:10px;font-size:8px;display:flex;box-shadow:0 3px 12px #60748e0e}.promotion-article article li svg{color:#2876e8;width:15px;height:15px}.article-cta{color:#fff;background:#2876e8;border:0;border-radius:11px;width:calc(100% - 36px);margin:0 18px;padding:13px;font-size:9px;font-weight:700;display:block;box-shadow:0 9px 20px #2876e833}.portal-shell{--xom-navy:#002b67;--xom-blue:#0568e8;--xom-blue-2:#2f8cff;--xom-lime:#b5d600;--xom-ink:#102849;--xom-muted:#708198;--xom-line:#e4ebf4;--xom-bg:#f4f7fb;--xom-card:#fff;letter-spacing:-.012em;background:radial-gradient(circle at 50% 0,#e7f0ff 0,#f6f8fb 48%,#edf2f8 100%);font-family:Manrope,Segoe UI,sans-serif}.phone-app{background:var(--xom-bg);letter-spacing:-.012em;border-radius:38px;width:414px;height:min(896px,100vh - 36px);box-shadow:0 24px 80px #123d7226,0 0 0 1px #fff}.mobile-page{background:var(--xom-bg);inset:0 0 76px}.home-page{padding:0 16px 26px}.home-head{background:linear-gradient(140deg,var(--xom-navy),var(--xom-blue) 73%,#2f8cff);color:#fff;align-items:center;height:150px;margin:0 -16px 14px;padding:25px 18px 20px;position:relative;overflow:hidden}.home-head:after{content:"";border:38px solid #ffffff0a;border-radius:50%;width:210px;height:210px;position:absolute;bottom:-120px;right:-115px}.home-brand-logo{object-fit:contain;z-index:1;background:#fff;border-radius:21px;width:72px;height:72px;padding:6px;box-shadow:0 10px 26px #001b4144}.home-head>div:nth-child(2){z-index:1}.home-head small{letter-spacing:.01em;color:#d9e8ff;font-size:10px}.home-head h2{letter-spacing:-.035em;margin:6px 0 0;font-size:18px;font-weight:750;line-height:1.32}.home-head h2 strong{color:#d8ee45;font-weight:800}.home-head button{color:#fff;z-index:2;background:#ffffff16;border-radius:12px;place-items:center;width:38px;height:38px;display:grid}.home-head button svg{stroke-width:2px;width:19px;height:19px}.home-head em{border:2px solid var(--xom-blue);background:#ff6b5c;font-weight:800;top:-4px;right:-3px}.promo-slider{border-radius:20px;height:182px;box-shadow:0 14px 32px #003b8630}.promo-slide{padding:25px 22px}.promo-slide.blue{background:linear-gradient(135deg,#004294,#0875f3 70%,#3ca0ff)}.promo-slide.navy{background:linear-gradient(135deg,#001d49,#004b94)}.promo-slide.lime{background:linear-gradient(135deg,#476f00,#9cbd00)}.promo-slide>div{width:228px}.promo-slide small{letter-spacing:.12em;font-size:8px;font-weight:800}.promo-slide h1{letter-spacing:-.045em;margin:12px 0 5px;font-size:21px}.promo-slide p{letter-spacing:-.01em;font-size:9px;line-height:1.45}.promo-slide span{color:var(--xom-navy);letter-spacing:-.01em;border-radius:10px;padding:9px 12px;font-size:8px}.promo-slide img{width:146px;height:146px;bottom:-12px;right:-12px}.promo-dots{bottom:12px;left:auto;right:18px}.section-title{margin:24px 2px 12px}.section-title b{color:var(--xom-ink);letter-spacing:-.025em;font-size:13px;font-weight:800}.section-title button{color:var(--xom-blue);letter-spacing:0;font-size:8px;font-weight:750}.next-appointment,.appointment-card,.service-card,.detail-card,.health-summary,.health-history,.form-card,.invoice-row,.support-link,.coupon{border:1px solid var(--xom-line);box-shadow:0 8px 24px #173a6610}.next-appointment{border-radius:18px;grid-template-columns:58px 1fr auto;padding:14px}.date-badge{width:58px;height:62px;color:var(--xom-blue);background:linear-gradient(145deg,#eaf3ff,#f7faff);border:1px solid #dbe9fb;border-radius:14px}.date-badge b{letter-spacing:-.05em;font-size:22px}.date-badge small{text-transform:uppercase;letter-spacing:.03em;font-size:7px;font-weight:700}.next-appointment>div:nth-child(2) b{color:var(--xom-ink);letter-spacing:-.02em;font-size:11px}.next-appointment>div:nth-child(2) small{letter-spacing:0;font-size:8px}.m-status{letter-spacing:0;padding:6px 9px;font-size:7px;font-weight:750}.quick-services{gap:9px}.quick-services button{background:#fff;border:1px solid #dce7f6;border-radius:17px;justify-content:flex-start;height:110px;padding:7px;box-shadow:0 8px 20px #133e7212}.quick-services img{border-radius:12px;height:70px}.quick-services span{color:var(--xom-ink);letter-spacing:-.025em;font-size:6.5px;font-weight:750;line-height:1.3}.points-card{background:linear-gradient(130deg,var(--xom-navy),var(--xom-blue));border-radius:18px;height:82px;padding:18px;box-shadow:0 12px 26px #0051bc26}.points-card small{color:#d9e9ff;letter-spacing:.02em;font-size:8px}.points-card b{letter-spacing:-.035em;font-size:18px}.points-card svg{color:#d8ee45;stroke-width:1.8px}.mobile-bottom-nav{background:#fffffffa;border:0;height:76px;padding:5px 8px 8px;box-shadow:0 -8px 28px #153d6c10}.mobile-bottom-nav button{color:#8290a4;border-radius:14px;gap:5px;transition:all .2s}.mobile-bottom-nav button.active{color:var(--xom-blue);background:#edf5ff}.mobile-bottom-nav svg{stroke-width:1.8px;width:21px;height:21px}.mobile-bottom-nav button.active svg{stroke-width:2.4px}.mobile-bottom-nav small{letter-spacing:-.01em;font-size:7px;font-weight:650}.mobile-topbar{border-bottom:1px solid var(--xom-line);grid-template-columns:54px 1fr 54px;height:72px}.mobile-topbar b{color:var(--xom-navy);letter-spacing:-.03em;font-size:14px;font-weight:800}.mobile-topbar button{width:42px;height:42px;color:var(--xom-blue);border-radius:12px;margin:auto}.segment{border-color:var(--xom-line);gap:8px;height:55px;padding:0 12px}.segment button{border:0;border-radius:12px;margin:8px 0;font-size:9px;font-weight:700}.segment button.active{background:var(--xom-blue);color:#fff;box-shadow:0 6px 14px #0568e82e}.appointment-content,.service-content,.detail-content,.health-content{padding:18px 14px 30px}.appointment-content h3,.health-content h3,.subpage-content h3{color:var(--xom-ink);letter-spacing:-.025em;font-size:11px;font-weight:800}.appointment-card{border-radius:18px;grid-template-columns:58px 1fr auto;gap:11px;margin-bottom:12px;padding:14px}.appointment-card .appointment-info b{color:var(--xom-ink);letter-spacing:-.025em;font-size:10.5px}.appointment-card .appointment-info small{letter-spacing:0;font-size:7.5px}.appointment-card .card-detail{color:var(--xom-blue);font-size:7.5px;font-weight:700}.mobile-search{height:46px;box-shadow:none;background:#fff;border:1px solid #dce6f2;border-radius:14px;padding:0 14px}.mobile-search input{letter-spacing:-.01em;font-size:9px}.category-scroll{gap:7px;margin:14px -14px;padding:0 14px}.category-scroll button{background:#fff;border:1px solid #e1e9f3;padding:8px 13px;font-size:8px;font-weight:700}.category-scroll button.active{background:var(--xom-blue);border-color:var(--xom-blue);box-shadow:0 5px 12px #0568e826}.result-count{letter-spacing:.01em;font-size:7.5px}.service-card{border-radius:18px;grid-template-columns:78px 1fr 18px;gap:12px;margin-bottom:11px;padding:10px}.service-card>img{border-radius:14px;width:78px;height:78px}.service-card b{color:var(--xom-ink);letter-spacing:-.025em;font-size:10px}.service-card small{font-size:7px;line-height:1.5}.service-card strong{color:var(--xom-blue);letter-spacing:-.015em;font-size:10px}.service-card>div em{color:#5d7800;background:#eef6dc;font-weight:750}.detail-card{border-radius:20px;padding:16px}.detail-card h2{color:var(--xom-navy);letter-spacing:-.035em;font-size:15px}.detail-card dl>div{grid-template-columns:95px 1fr;padding:14px 0}.detail-card dt{color:#667a92;font-size:8px;font-weight:700}.detail-card dt svg{color:var(--xom-blue)}.detail-card dd{color:var(--xom-ink);font-size:9px}.detail-actions button,.primary-action,.sheet-submit,.article-cta{background:var(--xom-blue);letter-spacing:-.01em;border-radius:12px;font-weight:750;box-shadow:0 8px 20px #0568e828}.detail-actions button:last-child{color:#d44e59;box-shadow:none;background:#fff0f1}.support-card{background:linear-gradient(135deg,#f5f9ff,#eaf3ff);border:1px solid #dce9f7;border-radius:18px}.support-card strong{color:var(--xom-blue)}.support-card button{background:var(--xom-navy);border-radius:13px}.profile-page{background:var(--xom-bg)}.profile-hero{background:linear-gradient(145deg,var(--xom-navy),var(--xom-blue) 78%,#3a9dff);height:250px;padding:22px 20px 0}.profile-logo{object-fit:contain;opacity:.96;background:#fff;border-radius:12px;width:100px;height:45px;padding:4px;position:absolute;top:14px;right:52px}.profile-actions b{letter-spacing:-.025em;font-size:15px;font-weight:800}.profile-person{margin-top:48px}.profile-person h2{letter-spacing:-.04em;font-size:18px}.profile-person p,.profile-person small{letter-spacing:.01em}.profile-hero>span{color:var(--xom-navy);font-size:7px;font-weight:750}.profile-menu{border-radius:22px 22px 0 0;margin-top:-20px;padding:12px 16px}.profile-menu button{border-color:var(--xom-line);grid-template-columns:36px 1fr 18px;height:56px}.profile-menu i{width:32px;height:32px;color:var(--xom-blue);background:#edf5ff;border-radius:10px}.profile-menu i svg{width:16px;height:16px}.profile-menu b{color:var(--xom-ink);letter-spacing:-.018em;font-size:9.5px;font-weight:650}.identity-card,.balance-card,.reward-hero{background:linear-gradient(140deg,var(--xom-navy),var(--xom-blue) 80%,#3d9fff);border-radius:20px}.health-summary,.health-history{border-radius:18px}.health-summary i{color:var(--xom-blue);background:#edf5ff}.health-note{background:linear-gradient(135deg,#f4f8ff,#e8f2ff);border:1px solid #dce8f6;border-radius:18px}.health-note>svg,.invoice-row>svg,.support-link>svg,.coupon>svg,.settings-list>button>svg{color:var(--xom-blue)}.toggle.on{background:var(--xom-blue)}.reward-hero>svg{color:#d8ee45}.coupon button{color:var(--xom-blue);background:#edf5ff;font-weight:700}.support-hero>svg{color:var(--xom-blue)}.booking-sheet{border-radius:28px 28px 0 0;padding:12px 22px 25px}.sheet-title small{color:var(--xom-blue);letter-spacing:.1em;font-weight:800}.sheet-title h2{color:var(--xom-navy);letter-spacing:-.035em;font-size:18px}.booking-sheet input,.booking-sheet select{border-color:#dce6f1;border-radius:11px}.promo-slide.lime,.article-hero.lime{background:linear-gradient(135deg,#375c00,#8fad00)}.article-hero.blue{background:linear-gradient(135deg,var(--xom-navy),var(--xom-blue))}.article-hero.navy{background:linear-gradient(135deg,#001739,#004384)}.article-cta{background:var(--xom-blue)}.promotion-article article h2{color:var(--xom-navy);letter-spacing:-.035em}.article-expiry{color:var(--xom-blue);background:#edf5ff}@media (width<=600px){.phone-app{border-radius:0;width:100%;height:100vh}.home-head{border-radius:0 0 24px 24px}.mobile-page{inset:0 0 74px}.quick-services{gap:7px}.quick-services button{height:104px}.quick-services img{height:66px}}.home-brand-logo{border-radius:15px!important;width:84px!important;height:54px!important;padding:5px 7px!important}.login-page{color:#17382f;background:#f3f7f5;grid-template-columns:1.05fr .95fr;min-height:100vh;display:grid}.login-brand{color:#fff;background:linear-gradient(145deg,#092f4f,#0d5b63 58%,#85b92b);flex-direction:column;justify-content:space-between;padding:55px 70px;display:flex;position:relative;overflow:hidden}.login-brand:after{content:"";border:80px solid #ffffff0d;border-radius:50%;width:520px;height:520px;position:absolute;bottom:-230px;right:-250px}.login-brand>img{background:#fff;border-radius:22px;width:235px;padding:10px}.login-brand>div{z-index:2;position:relative}.login-brand span{letter-spacing:2px;color:#d9edb8;font-size:10px}.login-brand h1{letter-spacing:-3px;margin:18px 0;font-size:65px;line-height:1.05}.login-brand p{color:#c5dcd7;max-width:380px;font-size:13px;line-height:1.7}.login-panel{place-items:center;padding:35px;display:grid}.login-panel form{background:#fff;border:1px solid #e0eae6;border-radius:24px;width:min(390px,100%);padding:30px;box-shadow:0 20px 55px #17382f12}.login-logo{width:150px;margin:0 auto 22px;display:block}.login-panel h2{text-align:center;margin:0 0 7px;font-size:21px}.login-panel form>p{text-align:center;color:#7d918a;margin-bottom:22px;font-size:9px}.login-panel label{color:#587168;margin:12px 0;font-size:9px;font-weight:700;display:block}.login-panel label div{border:1px solid #dce7e2;border-radius:10px;align-items:center;gap:8px;height:43px;margin-top:6px;padding:0 11px;display:flex}.login-panel label svg{color:#799088;width:15px}.login-panel input{border:0;outline:0;width:100%;font-size:10px}.login-panel form>em{color:#d35e54;background:#fff0ef;border-radius:8px;padding:8px;font-size:8px;font-style:normal;display:block}.login-submit{color:#fff;background:#17382f;border:0;border-radius:10px;justify-content:center;align-items:center;gap:7px;width:100%;margin-top:16px;padding:12px;font-size:10px;font-weight:700;display:flex}.login-submit svg{width:15px}.login-security{background:#eff8f4;border-radius:9px;align-items:center;gap:8px;margin-top:12px;padding:9px;display:flex}.login-security svg{color:#1aa77c;width:16px}.login-security b,.login-security small{font-size:7px;display:block}.login-security small{color:#82958e;margin-top:2px}.demo-users{border-top:1px solid #e8efec;margin-top:18px;padding-top:13px}.demo-users>small{color:#8b9c96;margin-bottom:7px;font-size:7px;display:block}.demo-users button{background:#f7faf9;border:0;border-radius:8px;justify-content:space-between;width:100%;margin:3px 0;padding:7px 9px;display:flex}.demo-users b,.demo-users span{font-size:7px}.demo-users span{color:#899a94}@media (width<=800px){.login-page{grid-template-columns:1fr}.login-brand{display:none}.login-panel{padding:18px}.login-panel form{padding:24px}}.finance-actions{gap:8px;display:flex}.finance-actions button{align-items:center;gap:6px;display:flex}.finance-actions svg,.stat svg{width:14px;height:14px}.finance-table{padding:0;overflow:hidden}.finance-heading{justify-content:space-between;align-items:center;padding:18px;display:flex}.finance-heading h3,.finance-heading p{margin:0}.finance-heading h3{font-size:13px}.finance-heading p,.finance-heading span{color:#879a93;margin-top:4px;font-size:8px}.finance-kind{border-radius:20px;padding:5px 7px;font-size:7px;font-weight:700;display:inline-block}.finance-kind.income{color:#149d74;background:#e1f7ef}.finance-kind.expense{color:#ce6757;background:#fff0ec}.finance-table td a{color:#168c6b;align-items:center;gap:4px;font-size:8px;text-decoration:none;display:flex}.finance-table td a svg{width:12px}.finance-form{background:#fff;border-radius:18px;width:min(680px,100%);max-height:92vh;padding:22px;overflow:auto}.finance-form header{justify-content:space-between;align-items:start;display:flex}.finance-form header span{color:#19a17a;font-size:7px}.finance-form header h2{margin:5px 0 17px;font-size:18px}.finance-form header button{background:#eff5f2;border:0;border-radius:50%;place-items:center;width:30px;height:30px;display:grid}.finance-form header svg{width:14px}.finance-form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.finance-form label{color:#5d756c;font-size:8px;font-weight:700}.finance-form label input,.finance-form label select,.finance-form label textarea{background:#fff;border:1px solid #dce7e2;border-radius:8px;width:100%;margin-top:5px;padding:10px;font-size:9px;display:block}.finance-form textarea{height:60px}.finance-form .full{grid-column:1/3}.proof-upload{background:#f2faf7;border:1px dashed #9bcbbd;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;height:90px;display:flex;position:relative}.proof-upload svg{color:#18a078;width:20px}.proof-upload b,.proof-upload small{margin-top:4px;font-size:8px}.proof-upload small{color:#83978f;font-size:6px}.proof-upload input{opacity:0;cursor:pointer;inset:0;margin:0!important;position:absolute!important}.submit-finance{width:100%;margin-top:15px}@media (width<=800px){.finance-form-grid{grid-template-columns:1fr}.finance-form .full{grid-column:1}.finance-actions{flex-direction:column}}.restore-button{cursor:pointer;align-items:center;gap:6px;display:flex;position:relative}.restore-button input{opacity:0;cursor:pointer;position:absolute;inset:0}:root{color:#183a32;font-synthesis:none;background:#f4f8f6;font-family:Manrope,Arial,sans-serif}*{box-sizing:border-box}body{margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}.logo{align-items:center;gap:11px;display:flex}.logo>span{color:#fff;background:#20bd8e;border-radius:13px;place-items:center;width:42px;height:42px;font-size:20px;font-weight:800;display:grid;box-shadow:0 8px 22px #20bd8e4d}.logo b,.logo small{display:block}.logo b{letter-spacing:.6px;font-size:13px}.logo small{color:#789189;margin-top:3px;font-size:8px}.sidebar{z-index:4;background:#fff;border-right:1px solid #e2ece8;flex-direction:column;width:230px;padding:24px 18px;display:flex;position:fixed;inset:0 auto 0 0}.sidebar .logo{margin:0 7px 36px}.sidebar nav{flex-direction:column;gap:5px;display:flex}.sidebar nav button{color:#71877f;text-align:left;background:0 0;border:0;border-radius:11px;align-items:center;gap:12px;padding:13px 14px;font-size:13px;font-weight:600;display:flex}.sidebar nav button span{width:18px;font-size:17px}.sidebar nav button.active{color:#129c74;background:#e2f8f1}.sidebar nav em{color:#fff;background:#ec806f;border-radius:50%;place-items:center;width:20px;height:20px;margin-left:auto;font-size:9px;font-style:normal;display:grid}.sidebar-bottom{margin-top:auto}.role-switch{background:#f7faf9;border:1px solid #dfeae6;border-radius:10px;padding:3px;display:flex}.role-switch button{color:#799088;background:0 0;border:0;border-radius:7px;flex:1;padding:8px;font-size:10px}.role-switch button.selected{color:#fff;background:#183a32}.reset{color:#91a39d;background:0 0;border:0;width:100%;padding:12px;font-size:9px}.user{border-top:1px solid #e2ece8;align-items:center;gap:10px;padding-top:16px;display:flex}.user b,.user small{font-size:10px;display:block}.user small{color:#8ea19a;margin-top:3px}.avatar{color:#15a67c;background:#dff7ef;border-radius:50%;flex:none;place-items:center;width:36px;height:36px;font-size:10px;font-weight:800;display:inline-grid}.admin-main{min-height:100vh;margin-left:230px;padding:27px 32px}.page-title{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-title h1{letter-spacing:-.5px;margin:0 0 6px;font-size:23px}.page-title p{color:#849890;margin:0;font-size:11px}.button{border:0;border-radius:9px;padding:11px 15px;font-size:11px;font-weight:700}.button.primary{color:#fff;background:#20bd8e}.button.secondary{color:#526e65;background:#fff;border:1px solid #dae7e2}.button.light{color:#118e6a;background:#fff}.stats{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px;display:grid}.stat,.card{background:#fff;border:1px solid #e2ece8;border-radius:14px;box-shadow:0 6px 22px #183a3208}.stat{padding:17px}.stat>div{color:#748b83;justify-content:space-between;font-size:10px;display:flex}.stat i{color:#16a77d;background:#e2f8f1;border-radius:8px;place-items:center;width:27px;height:27px;font-size:14px;font-style:normal;display:grid}.stat b{margin:8px 0 5px;font-size:21px;display:block}.stat small{color:#18a77c;font-size:8px}.dashboard-grid{grid-template-columns:1.1fr .9fr;gap:14px;display:grid}.card{padding:18px}.card-title{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.card-title h3{margin:0;font-size:13px}.card-title button{color:#17a67c;background:0 0;border:0;font-size:9px}.revenue-total{align-items:center;gap:10px;display:flex}.revenue-total b{font-size:23px}.revenue-total span{color:#18a77c;background:#e2f8f1;border-radius:20px;padding:5px 7px;font-size:8px}.chart{align-items:end;gap:18px;height:170px;padding:20px 8px 0;display:flex}.chart div{flex-direction:column;flex:1;justify-content:end;align-items:center;gap:7px;height:100%;display:flex}.chart i{background:linear-gradient(#20bd8e,#a4ead5);border-radius:7px 7px 2px 2px;width:100%;max-width:38px;display:block}.chart small{color:#91a39d;font-size:8px}.chart.large{height:280px}.upcoming-row{border-bottom:1px solid #ecf2ef;grid-template-columns:38px 36px 1fr auto;align-items:center;gap:8px;padding:11px 0;display:grid}.upcoming-row time{font-size:10px;font-weight:800}.upcoming-row b,.upcoming-row small{font-size:9px;display:block}.upcoming-row small{color:#8da099;margin-top:3px}.status{white-space:nowrap;border-radius:20px;padding:5px 7px;font-size:7px;font-weight:700;display:inline-block}.status-đã-xác-nhận{color:#159b73;background:#e2f8f1}.status-chờ-xác-nhận{color:#c78426;background:#fff3df}.status-hoàn-thành{color:#5675be;background:#e8eefb}.status-đã-hủy{color:#ce6659;background:#fdebea}.chairs{grid-column:1/3}.chair-grid{grid-template-columns:repeat(8,1fr);gap:8px;display:grid}.chair{background:#f1edfd;border-left:3px solid #947bdd;border-radius:8px;padding:9px}.chair.ready{background:#e7f8f2;border-color:#20bd8e}.chair.cleaning{background:#fff6e8;border-color:#e9aa4b}.chair b,.chair span{font-size:8px;display:block}.chair span{color:#869b94;margin-top:4px;font-size:7px}.toolbar{align-items:center;gap:12px;margin-bottom:14px;display:flex}.search-input{background:#fff;border:1px solid #dce8e3;border-radius:10px;outline:none;width:330px;padding:11px 13px;font-size:10px}.search-input:focus,input:focus,select:focus,textarea:focus{border-color:#20bd8e;outline:none}.filter-tabs{background:#fff;border:1px solid #e2ece8;border-radius:10px;gap:4px;padding:3px;display:flex}.filter-tabs button{color:#71877f;background:0 0;border:0;border-radius:7px;padding:8px 11px;font-size:8px}.filter-tabs button.active{color:#fff;background:#183a32}.table-card{padding:0;overflow:hidden}.table-wrap{overflow:auto}table{border-collapse:collapse;width:100%;font-size:10px}th{text-align:left;color:#7a9088;text-transform:uppercase;letter-spacing:.5px;background:#f8faf9;padding:13px 16px;font-size:8px}td{color:#577068;border-top:1px solid #ecf2ef;padding:13px 16px}td b,td small{color:#26483f;font-size:9px;display:block}td small{color:#91a39d;margin-top:4px;font-size:8px}.person-cell{align-items:center;gap:9px;display:flex}.status-select{color:#587269;border:1px solid #dce8e3;border-radius:7px;padding:6px;font-size:8px}.clickable{cursor:pointer}.clickable:hover{background:#f5fbf8}.debt{color:#cf6a5e;font-weight:700}.paid{color:#17a67c;font-weight:700}.empty{text-align:center;color:#8da099;padding:50px}.empty span{font-size:30px}.empty b{color:#49675e;margin:10px;display:block}.empty p{font-size:10px}.treatment-list{max-width:850px}.treatment-row{border-top:1px solid #edf2f0;align-items:center;gap:12px;padding:13px 0;display:flex}.treatment-row .grow{flex:1}.treatment-row b,.treatment-row small{font-size:10px;display:block}.treatment-row small{color:#91a39d;margin:4px 0 8px;font-size:8px}.progress{background:#e8efec;border-radius:10px;height:5px;overflow:hidden}.progress i{background:#20bd8e;border-radius:10px;height:100%;display:block}.treatment-row strong{color:#18a77c;font-size:11px}.service-rank{border-bottom:1px solid #edf2f0;align-items:center;gap:10px;padding:14px 0;display:flex}.service-rank>span{color:#18a77c;background:#e4f8f2;border-radius:8px;place-items:center;width:25px;height:25px;font-size:9px;display:grid}.service-rank div{flex:1}.service-rank b,.service-rank small{font-size:9px;display:block}.service-rank small{color:#91a39d;margin-top:4px;font-size:8px}.service-rank strong{font-size:10px}.modal-backdrop{z-index:20;background:#15352d88;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{background:#fff;border-radius:17px;width:min(650px,100%);max-height:90vh;overflow:auto;box-shadow:0 30px 80px #102b2466}.modal>header{border-bottom:1px solid #e6eeeb;justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal h2{margin:0;font-size:16px}.modal>header button{color:#678078;background:#eef4f1;border:0;border-radius:50%;width:30px;height:30px}.appointment-form{padding:20px}.form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-grid label{color:#597269;font-size:9px;font-weight:700}.form-grid input,.form-grid select,.form-grid textarea{background:#fff;border:1px solid #dce8e3;border-radius:8px;width:100%;margin-top:6px;padding:10px;font-size:10px;display:block}.form-grid textarea{resize:vertical;height:70px}.form-grid .full{grid-column:1/3}.form-actions{justify-content:flex-end;gap:8px;margin-top:18px;display:flex}.patient-detail{padding:22px}.patient-hero{align-items:center;gap:12px;display:flex}.patient-hero .avatar,.profile-head .avatar{width:54px;height:54px;font-size:14px}.patient-hero h3,.patient-hero p{margin:0}.patient-hero h3{font-size:16px}.patient-hero p{color:#879b94;margin-top:5px;font-size:9px}.detail-grid{grid-template-columns:1fr 1fr;gap:10px;margin:20px 0;display:grid}.detail-grid div{background:#f4f8f6;border-radius:10px;padding:13px}.detail-grid small,.detail-grid b{font-size:8px;display:block}.detail-grid b{margin-top:5px;font-size:11px}.patient-detail h4{font-size:11px}.history div{gap:10px;margin:13px 0;display:flex}.history i,.timeline-row>i{color:#17a77d;background:#e1f8f0;border-radius:50%;place-items:center;width:24px;height:24px;font-size:8px;font-style:normal;display:grid}.history b,.history small{font-size:9px;display:block}.history small{color:#91a39d;margin-top:4px;font-size:7px}.toast{color:#fff;z-index:30;background:#183a32;border-radius:10px;padding:13px 17px;font-size:10px;position:fixed;bottom:25px;right:25px;box-shadow:0 15px 40px #183a3244}.customer-app{background:#f4f8f6;min-height:100vh}.customer-header{z-index:5;background:#fff;border-bottom:1px solid #e2ece8;align-items:center;gap:45px;height:72px;padding:0 max(24px,50vw - 580px);display:flex;position:sticky;top:0}.customer-header nav{align-self:stretch;display:flex}.customer-header nav button{color:#728980;background:0 0;border:0;border-bottom:2px solid #0000;padding:0 18px;font-size:10px;font-weight:600}.customer-header nav button.active{color:#159e76;border-color:#20bd8e}.customer-header .role-switch{width:180px;margin-left:auto}.customer-main{min-height:calc(100vh - 72px)}.customer-content{max-width:1160px;margin:auto;padding:25px 0 50px}.customer-hero{color:#fff;background:linear-gradient(120deg,#173a31,#147b60);border-radius:22px;justify-content:space-between;height:330px;padding:45px 55px;display:flex;position:relative;overflow:hidden}.customer-hero:after{content:"";background:#ffffff0c;border-radius:50%;width:420px;height:420px;position:absolute;top:-170px;right:-80px}.customer-hero span{color:#aad8ca;font-size:10px}.customer-hero h1{letter-spacing:-1.5px;margin:12px 0;font-size:36px;line-height:1.12}.customer-hero p{color:#b9d9cf;width:420px;margin-bottom:22px;font-size:10px;line-height:1.6}.hero-tooth{z-index:1;background:#20bd8e;border-radius:50px;place-items:center;width:190px;height:190px;margin:20px 50px 0 0;font-size:100px;font-weight:800;display:grid;position:relative;transform:rotate(9deg);box-shadow:0 30px 50px #08251e55}.hero-tooth small{letter-spacing:1px;text-align:center;font-size:8px;position:absolute;bottom:18px}.customer-stats{grid-template-columns:repeat(3,1fr);gap:13px;margin:16px 0;display:grid}.customer-stats>div{background:#fff;border:1px solid #e2ece8;border-radius:13px;align-items:center;gap:11px;padding:15px;display:flex}.customer-stats i{color:#17a67c;background:#e2f8f1;border-radius:10px;place-items:center;width:35px;height:35px;font-style:normal;display:grid}.customer-stats small,.customer-stats b{font-size:8px;display:block}.customer-stats b{margin-top:4px;font-size:10px}.customer-grid{grid-template-columns:1.25fr .75fr;gap:14px;display:grid}.my-appointment{border-top:1px solid #edf2f0;grid-template-columns:45px 1fr auto;align-items:center;gap:11px;padding:10px 0;display:grid}.date-block{color:#17a77d;background:#e2f8f1;border-radius:9px;place-items:center;width:42px;height:42px;display:grid}.date-block b{font-size:13px}.date-block small{margin-top:-8px;font-size:5px}.my-appointment>div:nth-child(2) b,.my-appointment>div:nth-child(2) small{font-size:9px;display:block}.my-appointment>div:nth-child(2) small{color:#91a39d;margin-top:4px;font-size:7px}.offer{color:#fff;background:linear-gradient(135deg,#20bd8e,#14765c);padding:28px}.offer span{letter-spacing:1px;font-size:7px}.offer h2{margin:12px 0;font-size:21px;line-height:1.2}.offer p{color:#cef0e5;margin-bottom:18px;font-size:8px}.customer-narrow{max-width:900px;margin:auto;padding:32px 0 60px}.booking-card{padding:10px}.treatment-hero{color:#fff;background:linear-gradient(120deg,#173a31,#147b60);border-radius:18px;justify-content:space-between;align-items:center;margin-bottom:15px;padding:30px 40px;display:flex}.treatment-hero span{color:#acd8ca;font-size:8px}.treatment-hero b{color:#50d5ad;margin:7px 0;font-size:50px;display:block}.treatment-hero p{color:#b8d8ce;font-size:9px}.light-progress{background:#ffffff29;width:400px}.light-progress i{background:#53d7af}.aligner{background:#20bd8e;border-radius:30px;place-items:center;width:110px;height:110px;font-size:55px;font-weight:800;display:grid;transform:rotate(8deg)}.timeline{padding:23px}.timeline-row{border-top:1px solid #edf2f0;align-items:center;gap:12px;padding:13px 0;display:flex}.timeline-row>i{background:#fff;border:1px solid #dce8e3}.timeline-row>i.done{color:#fff;background:#20bd8e;border-color:#20bd8e}.timeline-row b,.timeline-row small{font-size:9px;display:block}.timeline-row small{color:#91a39d;margin-top:4px;font-size:7px}.profile{margin-bottom:14px}.profile-head{align-items:center;gap:13px;display:flex}.profile-head div{flex:1}.profile-head h3,.profile-head p{margin:0}.profile-head h3{font-size:14px}.profile-head p{color:#879b94;margin-top:4px;font-size:8px}@media (width<=900px){.sidebar{width:70px;padding:18px 9px}.sidebar .logo div,.sidebar nav button:not(.active){font-size:0}.sidebar nav button,.sidebar nav button.active{justify-content:center;padding:13px}.sidebar nav button span{font-size:18px}.sidebar .logo>span{margin:auto}.sidebar-bottom .role-switch,.sidebar-bottom .reset,.user div{display:none}.admin-main{margin-left:70px;padding:20px}.stats{grid-template-columns:1fr 1fr}.dashboard-grid,.customer-grid{grid-template-columns:1fr}.chairs{grid-column:1}.chair-grid{grid-template-columns:repeat(4,1fr)}.customer-header{gap:15px;padding:0 15px}.customer-header nav button{padding:0 8px;font-size:8px}.customer-header .role-switch{width:130px}.customer-content,.customer-narrow{padding:20px}.customer-hero{padding:30px}.hero-tooth{display:none}.customer-stats,.form-grid{grid-template-columns:1fr}.form-grid .full{grid-column:1}.toolbar{flex-direction:column;align-items:stretch}.search-input{width:100%}}@media (width<=600px){.stats{grid-template-columns:1fr}.customer-header .logo div{display:none}.customer-header{gap:7px}.customer-header nav button{padding:0 5px}.customer-header .role-switch{width:90px}.customer-hero{height:auto}.customer-hero h1{font-size:28px}.customer-hero p{width:auto}.customer-stats{grid-template-columns:1fr}.page-title{align-items:flex-start;gap:10px}.page-title h1{font-size:18px}.chair-grid{grid-template-columns:repeat(2,1fr)}}.official-logo img{object-fit:contain;background:#fff;width:175px;max-height:72px}.sidebar .official-logo{margin:0 4px 28px}.sidebar .official-logo img{width:180px}.user small{max-width:145px;line-height:1.3}.chair-grid{grid-template-columns:repeat(2,minmax(160px,1fr));max-width:520px}
