:root{--primary:#35c77b;--primary-dark:#0f6b45;--primary-soft:#e9fff3;--orange:#ff8a3d;--yellow:#ffd166;--sea:#2bb3d9;--coral:#ff6b6b;--purple:#8b5cf6;--ink:#12372a;--text:#28483d;--muted:#73877f;--bg:#f7fcf8;--card:#fff;--line:#e4eee8;--shadow-sm:0 7px 20px rgba(15,107,69,.08);--shadow:0 18px 50px rgba(15,78,54,.12);--radius:22px;--radius-sm:14px;--sidebar:270px}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:"Plus Jakarta Sans",system-ui,sans-serif;line-height:1.65;-webkit-font-smoothing:antialiased}body.modal-open{overflow:hidden}a{color:var(--primary-dark);text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}img{max-width:100%;display:block}h1,h2,h3,h4{color:var(--ink);line-height:1.2;margin-top:0}h1{font-size:clamp(2rem,5vw,4.3rem);letter-spacing:-.045em}h2{font-size:clamp(1.55rem,3vw,2.45rem);letter-spacing:-.03em}h3{letter-spacing:-.015em}.container{width:min(1180px,calc(100% - 32px));margin-inline:auto}
.btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border:0;border-radius:13px;font-weight:700;transition:.22s ease;white-space:nowrap}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-primary{color:#fff;background:linear-gradient(135deg,var(--primary),#21ad69)}.btn-secondary{color:#fff;background:linear-gradient(135deg,var(--sea),#168daf)}.btn-warning{color:#67330b;background:var(--yellow)}.btn-danger{color:#fff;background:var(--coral)}.btn-outline{color:var(--primary-dark);background:#fff;border:1px solid #bde8ce}.btn-soft{color:var(--primary-dark);background:var(--primary-soft)}.btn-ghost{color:var(--ink);background:transparent}.btn-block{width:100%}.btn-sm{min-height:36px;padding:7px 11px;font-size:.84rem}.btn-lg{min-height:52px;padding:14px 24px}.icon-btn{width:44px;height:44px;border:1px solid var(--line);border-radius:13px;background:#fff;color:var(--ink);display:grid;place-items:center;font-size:1.2rem}.inline-form{display:inline-flex;margin:0 0 0 6px}
.brand{display:flex;align-items:center;gap:10px;color:var(--ink);font-size:1.18rem;font-weight:700;line-height:1}.brand strong{color:var(--primary)}.brand small{display:block;margin-top:5px;color:var(--muted);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase}.brand-mark{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--primary),var(--sea));box-shadow:0 8px 18px rgba(53,199,123,.25)}.brand-light{color:#fff}.brand-light small{color:rgba(255,255,255,.55)}
.public-navbar{position:sticky;top:0;z-index:900;background:rgba(255,255,255,.9);border-bottom:1px solid rgba(228,238,232,.85);backdrop-filter:blur(16px)}.nav-wrap{min-height:78px;display:flex;align-items:center;gap:22px}.nav-links{display:flex;align-items:center;justify-content:center;gap:4px;flex:1}.nav-links a{padding:9px 11px;border-radius:10px;color:#466257;font-size:.9rem;font-weight:600}.nav-links a:hover,.nav-links a.active{color:var(--primary-dark);background:var(--primary-soft)}.nav-actions{display:flex;gap:8px}.nav-toggle{display:none}
.hero{position:relative;overflow:hidden;padding:86px 0 72px;background:radial-gradient(circle at 85% 15%,rgba(255,209,102,.35),transparent 22%),radial-gradient(circle at 5% 90%,rgba(43,179,217,.19),transparent 28%),linear-gradient(135deg,#f5fff8 0%,#eafff3 48%,#eefbff 100%)}.hero:before,.hero:after{content:"";position:absolute;border-radius:50%;filter:blur(1px)}.hero:before{width:300px;height:300px;right:-120px;bottom:-150px;background:rgba(53,199,123,.14)}.hero:after{width:120px;height:120px;left:8%;top:-45px;background:rgba(255,138,61,.15)}.hero-grid{position:relative;display:grid;grid-template-columns:1.2fr .8fr;align-items:center;gap:46px}.hero h1{max-width:760px;margin:15px 0;color:#0c4d34}.hero p{font-size:1.08rem;color:#58756a;max-width:700px}.hero-card{padding:32px;background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.9);border-radius:30px;box-shadow:var(--shadow);backdrop-filter:blur(12px);transform:rotate(1deg)}.hero-card:before{content:"✦";display:grid;place-items:center;width:58px;height:58px;border-radius:18px;background:#fff3d2;color:var(--orange);font-size:1.8rem}.hero-card ul{padding:0;list-style:none}.hero-card li{padding:9px 0}.hero-card li:before{content:"✓";display:inline-grid;place-items:center;width:24px;height:24px;margin-right:9px;border-radius:50%;color:#fff;background:var(--primary);font-weight:800}.search-card{display:grid;grid-template-columns:1fr auto;gap:10px;margin-top:25px;padding:10px;border:1px solid rgba(53,199,123,.2);border-radius:18px;background:#fff;box-shadow:var(--shadow-sm)}.search-card input{border:0;outline:0;padding:10px;font-size:16px}.search-card button{border:0;border-radius:13px;padding:12px 22px;color:#fff;background:var(--orange);font-weight:800}.chip-row{display:flex;flex-wrap:wrap;gap:9px;margin-top:18px}.chip{padding:8px 13px;border-radius:999px;background:rgba(255,255,255,.8);border:1px solid #d8eee0;font-size:.85rem;font-weight:700;transition:.2s}.chip:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}
.section{padding:64px 0}.alt-bg{background:linear-gradient(180deg,#f0fff6,#f8fffb)}.section-head{display:flex;justify-content:space-between;align-items:end;gap:20px;margin-bottom:25px}.section-head h2{margin:3px 0}.eyebrow{margin:0 0 6px;color:var(--orange);font-size:.75rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.page-header{position:relative;padding:55px 0 30px}.page-header:before{content:"";position:absolute;left:0;top:22px;width:52px;height:7px;border-radius:9px;background:linear-gradient(90deg,var(--orange),var(--yellow))}.page-header h1{font-size:clamp(2rem,4vw,3.4rem);margin:7px 0}.page-header p{color:var(--muted)}
.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.card,.panel,.table-wrap,.form-card,.empty-state,.chart-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card{overflow:hidden;transition:.25s ease}.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}.card>img{width:100%;height:220px;object-fit:cover;border-radius:0;background:#e9f6ee}.card-body{padding:20px}.card-body h3{margin:9px 0}.card-body p{color:var(--muted)}.card-meta,.price-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.price-row{margin-top:15px}.price-row strong{color:var(--ink);font-size:1.05rem}.image-placeholder{height:210px;display:grid;place-items:center;background:linear-gradient(135deg,#eafff2,#eaf9ff);font-size:4.5rem}.panel{padding:24px;margin-bottom:20px}.panel h3{margin-bottom:18px}
.badge{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border-radius:999px;font-size:.74rem;font-weight:800;text-transform:capitalize}.badge-success{color:#087443;background:#dcfce9}.badge-warning{color:#9a540c;background:#fff2d1}.badge-info{color:#08799a;background:#def7ff}.badge-danger{color:#b42323;background:#ffe3e3}.badge-secondary{color:#53615c;background:#edf1ef}.badge-primary{color:#086a61;background:#d9faf5}.badge-purple{color:#6d37c4;background:#eee6ff}
.filter-bar{display:grid;grid-template-columns:2fr 1fr auto auto;gap:10px;padding:14px;margin-bottom:20px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm)}.filter-bar input,.filter-bar select,.form-group input,.form-group select,.form-group textarea{width:100%;min-height:46px;padding:11px 13px;border:1px solid #dce9e1;border-radius:12px;background:#fbfefc;color:var(--ink);font-size:16px;outline:0;transition:.2s}.form-group textarea{min-height:105px;resize:vertical}.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.filter-bar input:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(53,199,123,.12);background:#fff}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:15px}.form-group{margin-bottom:14px}.form-group label{display:block;margin:0 0 7px;color:#315044;font-size:.86rem;font-weight:700}.form-group input[type=checkbox]{width:auto;min-height:auto}.field-hint{font-size:.78rem;color:var(--muted)}.upload-preview{width:100%;max-height:220px;object-fit:cover;border:1px dashed #a9d8bb;border-radius:16px;margin:10px 0;background:var(--primary-soft)}
.table-wrap{padding:8px;overflow:auto}.table-wrap:before{content:"Data terbaru";display:block;padding:13px 14px 9px;color:var(--muted);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em}table{width:100%;border-collapse:separate;border-spacing:0;background:#fff}th{padding:13px 14px;color:#698078;background:#f4faf6;border-bottom:1px solid var(--line);font-size:.72rem;text-align:left;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}td{padding:14px;border-bottom:1px solid #edf3ef;font-size:.9rem;vertical-align:middle}tbody tr{transition:.18s}tbody tr:hover{background:#f8fffb}tbody tr:last-child td{border-bottom:0}.table-thumb{width:48px;height:48px;border-radius:12px;object-fit:cover}.table-actions{display:flex;align-items:center;gap:6px}.empty-state{padding:55px 24px;text-align:center;color:var(--muted)}.empty-state:before{content:"☀";display:grid;place-items:center;width:72px;height:72px;margin:0 auto 15px;border-radius:24px;background:#fff4d8;color:var(--orange);font-size:2rem}
.app-modal{position:fixed;inset:0;z-index:3000;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(8,48,32,.52);backdrop-filter:blur(5px)}.app-modal.open{display:flex}.modal-dialog{width:min(820px,100%);max-height:min(88vh,900px);overflow:auto;background:#fff;border-radius:26px;box-shadow:0 30px 90px rgba(0,0,0,.24);animation:modalIn .22s ease}.modal-header{position:sticky;top:0;z-index:3;display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(10px)}.modal-header h3{margin:0}.modal-body{padding:24px}.modal-close{width:40px;height:40px;border:0;border-radius:12px;background:#f1f7f3;color:var(--ink);font-size:1.15rem}@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.footer{position:relative;margin-top:50px;padding:65px 0 20px;color:rgba(255,255,255,.72);background:linear-gradient(145deg,#0b5035,#073d2b)}.footer:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 90% 10%,rgba(43,179,217,.16),transparent 25%);pointer-events:none}.footer-grid{position:relative;display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:38px}.footer h4{color:#fff}.footer p{margin:8px 0}.footer-grid>div>a:not(.brand){display:block;padding:5px 0;color:rgba(255,255,255,.7)}.footer-grid>div>a:hover{color:#fff}.social-row{display:flex;gap:10px;margin-top:18px}.social-row a{width:40px;height:40px;display:grid;place-items:center;color:#fff!important;border-radius:12px;background:rgba(255,255,255,.1)}.footer-bottom{position:relative;display:flex;justify-content:space-between;gap:20px;margin-top:45px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);font-size:.82rem}.whatsapp-float{position:fixed;right:20px;bottom:20px;z-index:850;display:flex;align-items:center;gap:8px;padding:13px 16px;color:#fff!important;background:#20bd67;border-radius:999px;box-shadow:0 12px 30px rgba(32,189,103,.3);font-weight:800}.whatsapp-float i{font-size:1.2rem}.mobile-bottom-nav{display:none}
/* dashboard shells */
.admin-body,.member-body{min-height:100vh;background:#f3f8f5}.admin-sidebar,.member-sidebar{position:fixed;inset:0 auto 0 0;z-index:1200;width:var(--sidebar);display:flex;flex-direction:column;padding:18px 14px;color:#fff;background:linear-gradient(180deg,#0d6040,#073d2b);box-shadow:10px 0 40px rgba(10,73,49,.12);transition:.25s}.sidebar-brand{display:flex;align-items:center;justify-content:space-between;padding:3px 7px 22px}.sidebar-close{display:none;color:#fff;background:rgba(255,255,255,.1);border:0}.sidebar-label{padding:7px 13px;color:rgba(255,255,255,.42);font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.13em}.sidebar-nav{flex:1;overflow:auto;padding-right:2px}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.16);border-radius:4px}.sidebar-nav a,.sidebar-footer a{display:flex;align-items:center;gap:13px;margin:3px 0;padding:10px 13px;border-radius:12px;color:rgba(255,255,255,.68);font-size:.87rem;font-weight:600;transition:.18s}.sidebar-nav a i,.sidebar-footer a i{width:20px;font-size:1.03rem}.sidebar-nav a:hover,.sidebar-nav a.active{color:#fff;background:rgba(255,255,255,.12);transform:translateX(2px)}.sidebar-nav a.active:after{content:"";width:6px;height:6px;margin-left:auto;border-radius:50%;background:var(--yellow)}.sidebar-footer{padding-top:10px;border-top:1px solid rgba(255,255,255,.1)}.admin-shell,.member-shell{min-height:100vh;margin-left:var(--sidebar);display:flex;flex-direction:column}.admin-topbar{position:sticky;top:0;z-index:700;min-height:76px;display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:rgba(255,255,255,.92);border-bottom:1px solid var(--line);backdrop-filter:blur(14px)}.topbar-left,.topbar-actions,.user-chip{display:flex;align-items:center;gap:12px}.topbar-left small,.user-chip small{display:block;color:var(--muted);font-size:.72rem}.topbar-left strong,.user-chip strong{display:block;color:var(--ink);font-size:.9rem}.user-chip>span{width:42px;height:42px;display:grid;place-items:center;border-radius:13px;color:#fff;background:linear-gradient(135deg,var(--primary),var(--sea));font-weight:800}.admin-main,.member-main{flex:1;padding:28px}.admin-footer{padding:18px 28px;color:var(--muted);font-size:.78rem}.page-content{width:100%;max-width:1500px;margin:auto}.page-content>h2{margin-bottom:5px}.page-content>h2:after{content:"Kelola data dan aktivitas TravelJLS dengan lebih mudah.";display:block;margin-top:7px;color:var(--muted);font-size:.82rem;font-weight:500;letter-spacing:0}.page-title-row{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:20px}.page-title-row h2{margin:0}.page-title-row p{margin:5px 0 0;color:var(--muted)}
.dashboard-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.stat-card{position:relative;overflow:hidden;min-height:130px;padding:21px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:var(--shadow-sm)}.stat-card:after{content:"";position:absolute;width:85px;height:85px;right:-26px;bottom:-30px;border-radius:50%;background:var(--primary-soft)}.stat-card:nth-child(2):after{background:#fff2dc}.stat-card:nth-child(3):after{background:#def7ff}.stat-card:nth-child(4):after{background:#eee7ff}.stat-card h3{margin:0 0 16px;color:var(--muted);font-size:.78rem;font-weight:700}.stat-card .value{color:var(--ink);font-size:1.65rem;font-weight:800;letter-spacing:-.03em}.stat-icon{width:42px;height:42px;display:grid;place-items:center;margin-bottom:12px;border-radius:13px;color:var(--primary-dark);background:var(--primary-soft)}.chart-card{padding:22px}.chart-card canvas{max-height:290px}.timeline{position:relative;margin:20px 0;padding-left:28px}.timeline:before{content:"";position:absolute;left:8px;top:9px;bottom:9px;width:2px;background:#d8e9df}.timeline-item{position:relative;padding:0 0 21px}.timeline-item:before{content:"";position:absolute;left:-26px;top:6px;width:12px;height:12px;border:3px solid #fff;border-radius:50%;background:var(--primary);box-shadow:0 0 0 2px #b7e8ca}.sidebar-overlay{display:none;position:fixed;inset:0;z-index:1100;background:rgba(5,40,27,.5)}
.qty-control{display:flex;align-items:center;gap:8px;font-size:.84rem}.qty-control input{width:65px;min-height:40px;border:1px solid var(--line);border-radius:10px;padding:7px}.order-destination{margin-top:25px}.swal2-popup{border-radius:24px!important;font-family:"Plus Jakarta Sans",sans-serif!important}.swal2-confirm,.swal2-cancel{border-radius:12px!important;padding:11px 20px!important}.loading-overlay{position:fixed;inset:0;z-index:5000;display:grid;place-items:center;background:rgba(255,255,255,.7);backdrop-filter:blur(3px)}.loading-spinner{width:48px;height:48px;border:5px solid #dff6e8;border-top-color:var(--primary);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:1050px){.nav-links{display:none;position:absolute;left:16px;right:16px;top:72px;padding:14px;flex-direction:column;align-items:stretch;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}.nav-links.open{display:flex}.nav-toggle{display:grid;margin-left:auto}.nav-actions{display:none}.card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:800px){.admin-sidebar,.member-sidebar{transform:translateX(-105%);width:min(290px,85vw)}.admin-sidebar.open,.member-sidebar.open{transform:none}.sidebar-close{display:grid}.sidebar-overlay.open{display:block}.admin-shell,.member-shell{margin-left:0}.admin-topbar{padding:10px 16px}.admin-main,.member-main{padding:18px 14px}.user-chip div{display:none}.hero{padding:55px 0}.hero-grid{grid-template-columns:1fr}.hero-card{transform:none}.form-grid{grid-template-columns:1fr}.filter-bar{grid-template-columns:1fr 1fr}.footer-bottom{flex-direction:column}.whatsapp-float{bottom:83px}.whatsapp-float span{display:none}.whatsapp-float{width:54px;height:54px;justify-content:center;padding:0}.mobile-bottom-nav{position:fixed;left:10px;right:10px;bottom:9px;z-index:800;display:grid;grid-template-columns:repeat(4,1fr);padding:7px;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 40px rgba(18,55,42,.18);backdrop-filter:blur(12px)}.mobile-bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:2px;color:#698078;font-size:.64rem;font-weight:700}.mobile-bottom-nav i{font-size:1.15rem}.public-body{padding-bottom:76px}.footer{margin-bottom:-76px;padding-bottom:100px}.modal-dialog{max-height:94vh}.app-modal{padding:8px}.modal-body{padding:18px}.modal-header{padding:16px 18px}}
@media(max-width:600px){.container{width:min(100% - 22px,1180px)}h1{font-size:2.2rem}.section{padding:44px 0}.card-grid,.dashboard-grid,.footer-grid{grid-template-columns:1fr}.search-card{grid-template-columns:1fr}.search-card button{width:100%}.filter-bar{grid-template-columns:1fr}.section-head,.page-title-row{align-items:flex-start;flex-direction:column}.section-head .btn,.page-title-row .btn{width:100%}.card>img{height:200px}.table-wrap{border-radius:16px}.admin-main,.member-main{padding:15px 10px}.panel{padding:17px}.topbar-actions .icon-btn{display:none}.footer-grid{gap:22px}.swal2-popup{width:calc(100% - 22px)!important}.confirm-actions{flex-direction:column}}
@media print{.public-navbar,.footer,.whatsapp-float,.mobile-bottom-nav,.admin-sidebar,.member-sidebar,.admin-topbar,.btn{display:none!important}.admin-shell,.member-shell{margin:0}.panel,.table-wrap{box-shadow:none;border-color:#ccc}body{background:#fff}}
.dashboard-charts{display:grid;grid-template-columns:1.6fr .8fr;gap:18px;margin-top:18px}.ranking-list>div{display:grid;grid-template-columns:38px 1fr auto;align-items:center;gap:10px;padding:13px 0;border-bottom:1px solid var(--line)}.ranking-list>div>span{width:32px;height:32px;display:grid;place-items:center;border-radius:10px;color:var(--primary-dark);background:var(--primary-soft);font-weight:800}.ranking-list small{color:var(--muted)}.table-card{margin-top:18px;padding:22px;background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow-sm)}.table-card>.table-wrap{box-shadow:none;border:0;padding:0}.table-card>.table-wrap:before{display:none}.spin{display:inline-block;animation:spin .8s linear infinite}
.quick-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:13px}.quick-grid>a{display:flex;flex-direction:column;align-items:flex-start;gap:13px;padding:20px 15px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-sm);transition:.22s}.quick-grid>a:hover{transform:translateY(-5px);box-shadow:var(--shadow)}.quick-grid>a>span{width:48px;height:48px;display:grid;place-items:center;border-radius:15px;color:#fff;background:linear-gradient(135deg,var(--primary),#24a967);font-size:1.25rem}.quick-grid>a:nth-child(2)>span{background:linear-gradient(135deg,var(--sea),#188eae)}.quick-grid>a:nth-child(3)>span{background:linear-gradient(135deg,var(--orange),#ef6e1b)}.quick-grid>a:nth-child(4)>span{background:linear-gradient(135deg,var(--purple),#6939bd)}.quick-grid>a:nth-child(5)>span{background:linear-gradient(135deg,#ff6b6b,#ef4848)}.quick-grid>a:nth-child(6)>span{color:#805208;background:linear-gradient(135deg,var(--yellow),#ffbd29)}.quick-grid strong,.quick-grid small{display:block}.quick-grid strong{font-size:.9rem}.quick-grid small{margin-top:3px;color:var(--muted);font-size:.68rem}.section-lead{max-width:440px;color:var(--muted)}.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.feature-grid article{padding:25px;background:#fff;border:1px solid var(--line);border-radius:22px}.feature-grid article>span{width:52px;height:52px;display:grid;place-items:center;margin-bottom:18px;border-radius:16px;color:var(--primary-dark);background:var(--primary-soft);font-size:1.3rem}.feature-grid article:nth-child(2)>span{color:#a25315;background:#fff1dc}.feature-grid article:nth-child(3)>span{color:#087895;background:#e3f8ff}.feature-grid article:nth-child(4)>span{color:#6740a7;background:#f0e9ff}.feature-grid p{margin:0;color:var(--muted);font-size:.88rem}.testimonial-section{background:linear-gradient(135deg,#eafff2,#effbff)}.testimonial-card{display:grid;grid-template-columns:1.5fr .5fr;gap:30px;padding:45px;border-radius:30px;color:#fff;background:linear-gradient(135deg,#0f6b45,#0b503b);box-shadow:var(--shadow)}.testimonial-card h2{color:#fff}.testimonial-card p{color:rgba(255,255,255,.7)}.traveler{display:flex;align-items:center;gap:12px;margin-top:22px}.traveler>span{width:48px;height:48px;display:grid;place-items:center;border-radius:50%;color:var(--primary-dark);background:var(--yellow);font-weight:800}.traveler small,.testimonial-visual small{display:block;color:rgba(255,255,255,.55)}.testimonial-visual{display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:24px;background:rgba(255,255,255,.09)}.testimonial-visual i{font-size:3rem;color:var(--yellow)}.testimonial-visual .stars{color:var(--yellow);letter-spacing:.12em}.travel-cta{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:42px;border-radius:30px;background:radial-gradient(circle at 90% 10%,rgba(255,209,102,.4),transparent 30%),linear-gradient(135deg,#e9fff3,#ddf6ff)}.travel-cta h2{margin-bottom:8px}.travel-cta p{margin:0;color:var(--muted)}.detail-hero-image{width:100%;max-height:480px;object-fit:cover;margin-bottom:20px;border-radius:20px}.spin{display:inline-block;animation:spin .8s linear infinite}
@media(max-width:1050px){.quick-grid{grid-template-columns:repeat(3,1fr)}.feature-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:1050px){.dashboard-charts{grid-template-columns:1fr}}
.member-welcome{display:flex;justify-content:space-between;align-items:center;gap:25px;margin-bottom:22px;padding:28px;border-radius:25px;background:radial-gradient(circle at 90% 10%,rgba(255,209,102,.38),transparent 25%),linear-gradient(135deg,#e9fff3,#e7f8ff)}.member-welcome h2{margin:4px 0}.member-welcome p{margin:0;color:var(--muted)}.member-booking-list>a{display:grid;grid-template-columns:50px 1fr auto 20px;align-items:center;gap:13px;padding:15px 4px;border-bottom:1px solid var(--line);color:var(--text)}.booking-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:14px;color:var(--primary-dark);background:var(--primary-soft);font-size:1.1rem}.member-booking-list small,.booking-price strong{display:block}.member-booking-list small{margin-top:4px;color:var(--muted);font-size:.78rem}.booking-price{text-align:right}.booking-price .badge{margin-top:4px}
@media(max-width:650px){.member-welcome{align-items:flex-start;flex-direction:column}.member-welcome .btn{width:100%}.member-booking-list>a{grid-template-columns:46px 1fr 15px}.booking-price{grid-column:2;text-align:left}.member-booking-list>a>i{grid-column:3;grid-row:1/3}}
.back-link{display:inline-flex;align-items:center;gap:6px;margin-bottom:10px;color:var(--muted);font-size:.84rem;font-weight:700}.booking-detail-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:20px;align-items:start}.booking-detail-grid aside{position:sticky;top:95px}.booking-code,.account-number{display:flex;align-items:center;justify-content:space-between;gap:12px}.booking-code{padding-bottom:18px;border-bottom:1px solid var(--line)}.booking-code small,.summary-grid small,.payment-card>small,.payment-total small{display:block;color:var(--muted);font-size:.75rem}.booking-code strong{font-size:1.2rem;letter-spacing:.05em}.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding-top:20px}.summary-grid strong{display:block;margin-top:4px}.summary-grid .amount{color:var(--orange)}.delivery-card{display:flex;gap:14px;margin-top:20px;padding:16px;border-radius:16px;background:var(--primary-soft)}.delivery-card>i{color:var(--primary-dark);font-size:1.35rem}.delivery-card p{margin:3px 0}.payment-card{text-align:center}.payment-icon{width:64px;height:64px;display:grid;place-items:center;margin:0 auto 15px;border-radius:20px;color:var(--primary-dark);background:var(--primary-soft);font-size:1.6rem}.account-number{margin:14px 0;padding:11px 12px;border:1px dashed #a5dabc;border-radius:14px;background:#f8fffb}.account-number strong{font-size:1.18rem;letter-spacing:.06em}.payment-total{margin:15px 0;padding:16px;border-radius:16px;background:#fff4e8}.payment-total strong{display:block;color:var(--orange);font-size:1.35rem}.payment-card form{text-align:left;margin-top:18px}.timeline-item p{margin:4px 0;color:var(--muted)}.timeline-item small{color:#91a39b}
@media(max-width:950px){.booking-detail-grid{grid-template-columns:1fr}.booking-detail-grid aside{position:static}.summary-grid{grid-template-columns:repeat(2,1fr)}}
.sticky-booking-bar{display:none}.detail-info-grid{display:grid;grid-template-columns:1fr 340px;gap:22px}.facility-chips{display:flex;flex-wrap:wrap;gap:8px}.facility-chips span{padding:8px 11px;border-radius:999px;color:var(--primary-dark);background:var(--primary-soft);font-size:.82rem;font-weight:700}
@media(max-width:800px){.sticky-booking-bar{position:fixed;left:8px;right:8px;bottom:8px;z-index:950;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:18px;box-shadow:0 14px 45px rgba(18,55,42,.22);backdrop-filter:blur(12px)}.sticky-booking-bar small,.sticky-booking-bar strong{display:block}.sticky-booking-bar small{color:var(--muted);font-size:.66rem}.sticky-booking-bar strong{color:var(--ink);font-size:.88rem}.public-body:has(.sticky-booking-bar) .mobile-bottom-nav{display:none}.public-body:has(.sticky-booking-bar){padding-bottom:78px}}
.booking-steps{display:grid;grid-template-columns:repeat(4,1fr);margin-bottom:20px;padding:14px;background:#fff;border:1px solid var(--line);border-radius:18px}.booking-steps>div{position:relative;display:flex;align-items:center;gap:8px;color:var(--muted)}.booking-steps>div:not(:last-child):after{content:"";position:absolute;right:10px;width:35%;height:2px;background:var(--line)}.booking-steps span{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;background:#edf3ef;font-weight:800}.booking-steps .active{color:var(--primary-dark)}.booking-steps .active span{color:#fff;background:var(--primary)}.booking-steps small{font-size:.75rem;font-weight:700}
@media(max-width:650px){.booking-steps small{display:none}.booking-steps>div{justify-content:center}.booking-steps>div:not(:last-child):after{right:-20%;width:40%}}
.pagination{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin:14px 0}.pagination button{width:38px;height:38px;border:1px solid var(--line);border-radius:11px;background:#fff;color:var(--primary-dark)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{color:var(--muted);font-size:.78rem;font-weight:700}.client-filter{margin-top:18px}
@media(max-width:700px){.quick-grid{grid-template-columns:repeat(2,1fr)}.quick-grid>a{padding:16px 13px}.feature-grid{grid-template-columns:1fr}.testimonial-card{grid-template-columns:1fr;padding:26px}.testimonial-visual{min-height:170px}.travel-cta{align-items:flex-start;flex-direction:column;padding:28px}.travel-cta>div:last-child{width:100%}.travel-cta .btn{width:100%;margin:5px 0}}
.room-mini-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin-bottom:8px}.room-mini-gallery img{width:100%;height:65px;object-fit:cover;border-radius:9px}
.public-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.public-gallery-grid img{width:100%;height:260px;object-fit:cover;border-radius:18px;box-shadow:var(--shadow-sm);transition:.2s}.public-gallery-grid img:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.public-gallery-grid .empty-state{grid-column:1/-1}@media(max-width:800px){.public-gallery-grid{grid-template-columns:repeat(2,1fr)}.public-gallery-grid img{height:190px}}@media(max-width:480px){.public-gallery-grid{grid-template-columns:1fr}}
.multi-upload-preview{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}.multi-upload-preview img{width:100%;height:85px;object-fit:cover;border-radius:11px;border:1px solid var(--line)}@media(max-width:600px){.multi-upload-preview{grid-template-columns:repeat(2,1fr)}}
.gallery-admin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}.gallery-admin-grid article{padding:10px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm)}.gallery-admin-grid img{width:100%;height:175px;object-fit:cover;margin-bottom:9px;border-radius:13px}.gallery-admin-grid .empty-state{grid-column:1/-1}@media(max-width:900px){.gallery-admin-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:520px){.gallery-admin-grid{grid-template-columns:1fr}}
.user-avatar{width:42px;height:42px;display:grid;place-items:center;border-radius:13px;color:#fff;background:linear-gradient(135deg,var(--primary),var(--sea));font-weight:800}.badge-purple{color:#6d37c4;background:#eee6ff}
.booking-estimate{display:flex;align-items:center;gap:12px;margin:16px 0;padding:17px;border-radius:16px;background:linear-gradient(135deg,var(--primary-soft),#edfaff)}.booking-estimate span,.booking-estimate small{color:var(--muted)}.booking-estimate strong{margin-left:auto;color:var(--primary-dark);font-size:1.25rem}.booking-estimate small{flex-basis:100%;display:none}@media(max-width:600px){.booking-estimate{align-items:flex-start;flex-direction:column}.booking-estimate strong{margin-left:0}.booking-estimate small{display:block}}
.policy-page{max-width:920px}.policy-page details{margin:12px 0;background:#fff;border:1px solid var(--line);border-radius:17px;box-shadow:var(--shadow-sm)}.policy-page summary{padding:18px 20px;color:var(--ink);font-weight:800;cursor:pointer}.policy-page details p{padding:0 20px 18px;margin:0;color:var(--muted)}
.detail-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin:-5px 0 20px}.detail-gallery img{width:100%;height:125px;object-fit:cover;border-radius:14px}.room-image{width:100%;height:150px;object-fit:cover;margin-bottom:12px;border-radius:14px}@media(max-width:650px){.detail-gallery{grid-template-columns:repeat(2,1fr)}.detail-gallery img{height:105px}}
.login-callout{display:flex;align-items:center;gap:15px}.login-callout>i{font-size:1.8rem;color:var(--primary)}.login-callout div{flex:1}.login-callout p{margin:3px 0;color:var(--muted)}.invoice-page{margin:35px auto;padding:38px;background:#fff;border:1px solid var(--line);border-radius:24px}.invoice-head,.invoice-meta,.invoice-note,.invoice-totals>div{display:flex;justify-content:space-between;gap:20px}.invoice-head{align-items:start;padding-bottom:24px;border-bottom:3px solid var(--primary)}.invoice-head h1{font-size:2rem}.invoice-meta{padding:24px 0}.invoice-meta small,.invoice-meta strong,.invoice-meta span{display:block}.invoice-meta small{color:var(--muted)}.invoice-totals{width:min(380px,100%);margin:20px 0 20px auto}.invoice-totals>div{padding:7px 0}.invoice-totals .grand{padding-top:13px;border-top:2px solid var(--ink);font-size:1.2rem}.invoice-note{padding:18px;border-radius:16px;background:#f5faf7}.invoice-note strong,.invoice-note span{display:block;margin-bottom:5px}.invoice-page footer{margin-top:25px;text-align:center}@media(max-width:650px){.login-callout,.invoice-head,.invoice-meta,.invoice-note{align-items:flex-start;flex-direction:column}.login-callout .btn{width:100%}.invoice-page{padding:20px 14px}}
.success-card{max-width:820px;margin:25px auto;padding:42px;text-align:center;background:#fff;border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow)}.success-card h1{font-size:clamp(2rem,4vw,3.2rem);margin:12px 0}.success-icon{width:82px;height:82px;display:grid;place-items:center;margin:0 auto 20px;border-radius:28px;color:#fff;background:linear-gradient(135deg,var(--primary),#1fae69);font-size:2.2rem;box-shadow:0 15px 35px rgba(53,199,123,.3)}.success-code{display:flex;align-items:center;justify-content:center;gap:15px;margin:26px 0;padding:18px;border-radius:18px;background:var(--primary-soft)}.success-code strong{font-size:1.3rem;letter-spacing:.06em}.success-payment{display:grid;grid-template-columns:1fr 1fr;gap:14px;text-align:left}.success-payment>div{padding:18px;border:1px solid var(--line);border-radius:17px}.success-payment small,.success-payment span{display:block;color:var(--muted)}.success-payment strong{display:block;margin:5px 0;color:var(--ink)}.success-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:9px;margin-top:28px}@media(max-width:600px){.success-card{padding:25px 17px}.success-payment{grid-template-columns:1fr}.success-actions .btn{width:100%}}
.flash{margin:14px 0;padding:13px 16px;border-radius:14px;font-size:.88rem;font-weight:600}.flash-success{color:#087443;background:#dcfce9;border:1px solid #b7ebcd}.flash-error{color:#b42323;background:#ffe8e8;border:1px solid #ffcaca}.flash-warning{color:#8b520e;background:#fff3d6;border:1px solid #ffe2a3}.flash-info{color:#087895;background:#e1f8ff;border:1px solid #b9ebf8}

/* TravelJLS original visual pack */
.hero{background:linear-gradient(90deg,rgba(246,255,249,.98) 0%,rgba(246,255,249,.92) 38%,rgba(246,255,249,.48) 64%,rgba(246,255,249,.12) 100%),url('../img/travel/hero-jls.webp') center/cover no-repeat}
.image-placeholder{min-height:220px;color:transparent;background:url('../img/travel/culinary-jls.webp') center/cover no-repeat}
@media(max-width:800px){.hero{background-position:62% center}.hero:before{inset:0;width:auto;height:auto;border-radius:0;background:rgba(247,255,250,.34)}.hero-grid{position:relative;z-index:1}}

/* Balanced responsive page shell for wide and zoomed-out screens */
:root{--content-max:1440px;--page-gutter:clamp(20px,3.5vw,64px)}
.container{width:min(var(--content-max),calc(100% - (var(--page-gutter) * 2)));margin-inline:auto}
.page-content{width:min(100%,var(--content-max));margin-inline:auto}
.admin-main,.member-main{padding-inline:var(--page-gutter)}
.admin-topbar,.admin-footer{padding-inline:var(--page-gutter)}
@media(min-width:1500px){.hero{width:calc(100% - (var(--page-gutter) * 2));max-width:1600px;margin:28px auto 0;border-radius:34px}.hero-grid{grid-template-columns:minmax(0,1.15fr) minmax(340px,.85fr)}}
@media(max-width:800px){:root{--page-gutter:14px}.container{width:calc(100% - (var(--page-gutter) * 2))}.admin-main,.member-main{padding-inline:var(--page-gutter)}.admin-topbar,.admin-footer{padding-inline:var(--page-gutter)}}

/* Ticketing, profile and full-height travel layout */
.public-body{min-height:100vh;display:flex;flex-direction:column}.public-body>.footer{margin-top:auto}.admin-shell,.member-shell{min-height:100vh}.member-main,.admin-main{flex:1}.footer{position:relative;overflow:hidden;background:linear-gradient(145deg,#093f2e,#0d6545);}.footer:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 10% 100%,rgba(43,179,217,.18),transparent 28%),radial-gradient(circle at 90% 0,rgba(255,209,102,.18),transparent 25%);pointer-events:none}.footer>.container{position:relative}.footer-cta{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:45px;padding:30px;border-radius:24px;background:linear-gradient(135deg,#effff5,#e6f9ff);box-shadow:var(--shadow)}.footer-cta h2{margin:0}.footer-cta>div:last-child{display:flex;gap:10px}.member-footer{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:22px var(--page-gutter);color:var(--muted);background:#fff;border-top:1px solid var(--line)}.member-footer div span,.member-footer small{display:block;font-size:.75rem}.member-footer nav{display:flex;gap:18px;font-size:.82rem;font-weight:700}
.ticket-buy-card{display:flex;align-items:center;justify-content:space-between;gap:30px;margin:28px 0;padding:34px;border:1px solid #ccebd9;border-radius:28px;background:radial-gradient(circle at 90% 10%,rgba(255,209,102,.32),transparent 27%),linear-gradient(135deg,#effff5,#edfaff);box-shadow:var(--shadow-sm)}.ticket-buy-card h2{margin-bottom:8px}.ticket-checkout-grid{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:24px;align-items:start}.ticket-order-card{position:sticky;top:100px}.ticket-order-card>img{width:100%;height:190px;object-fit:cover;margin-bottom:18px;border-radius:18px}.ticket-total{display:flex;align-items:center;justify-content:space-between;margin:20px 0;padding:16px;border-radius:15px;background:var(--primary-soft)}.ticket-total strong{font-size:1.25rem}.participant-card{margin:16px 0;padding:19px;border:1px solid var(--line);border-radius:19px;background:#fbfefc}.participant-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.participant-head strong i{color:var(--primary);margin-right:8px}.check-row{display:flex;align-items:center;gap:9px;padding:13px;border-radius:13px;background:#f1fbf5}
.ticket-wallet-grid{display:grid;gap:16px}.wallet-ticket{position:relative;display:grid;grid-template-columns:1fr auto;align-items:center;gap:20px;padding:24px 28px;overflow:hidden;background:#fff;border:1px solid var(--line);border-left:7px solid var(--primary);border-radius:22px;box-shadow:var(--shadow-sm)}.wallet-ticket:after{content:"";position:absolute;right:180px;top:-12px;width:24px;height:24px;border-radius:50%;background:var(--bg);box-shadow:0 150px 0 var(--bg)}.wallet-ticket h3{margin:9px 0 5px}.wallet-ticket p{color:var(--muted)}.ticket-actions{display:flex;gap:8px}.participant-ticket-list{display:grid;gap:12px}.participant-ticket-list article{display:grid;grid-template-columns:50px 1fr auto auto;align-items:center;gap:14px;padding:17px;background:#fff;border:1px solid var(--line);border-radius:17px}.participant-ticket-list small{display:block;color:var(--muted)}.ticket-person-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:14px;color:var(--primary-dark);background:var(--primary-soft);font-size:1.2rem}
.profile-layout{display:grid;grid-template-columns:320px 1fr;gap:24px;align-items:start}.profile-layout aside{position:sticky;top:100px}.profile-avatar{width:116px;height:116px;margin:0 auto 15px;padding:5px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--sea),var(--yellow))}.profile-avatar img{width:100%;height:100%;object-fit:cover;border:4px solid #fff;border-radius:50%}.profile-card{text-align:center}.profile-stats{display:grid;grid-template-columns:1fr 1fr;margin-top:22px;border-top:1px solid var(--line)}.profile-stats div{padding:18px}.profile-stats div+div{border-left:1px solid var(--line)}.profile-stats strong,.profile-stats small{display:block}.profile-stats strong{font-size:1.4rem}.profile-progress .section-head{margin-bottom:12px}.progress{height:10px;overflow:hidden;margin:10px 0;border-radius:10px;background:#e5eee9}.progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--primary),var(--sea))}
.travel-timeline{position:relative;margin-left:15px;padding-left:30px;border-left:2px dashed #b9dfca}.travel-timeline article{position:relative;margin-bottom:18px;padding:20px;background:#fff;border:1px solid var(--line);border-radius:18px}.timeline-dot{position:absolute;left:-39px;top:28px;width:16px;height:16px;border:4px solid #fff;border-radius:50%;background:var(--primary);box-shadow:0 0 0 2px var(--primary)}.verify-ticket-card{max-width:720px;margin:30px auto;padding:42px;text-align:center;border:1px solid var(--line);border-radius:28px;background:#fff;box-shadow:var(--shadow)}.verify-ticket-card>i{font-size:4rem;color:var(--primary)}.verify-ticket-card.is-used>i,.verify-ticket-card.is-invalid>i{color:var(--danger)}.check-ticket-shell{max-width:780px;margin:auto}.ticket-admin-detail{display:grid;grid-template-columns:220px 1fr;gap:30px}.qr-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:180px;padding:20px;text-align:center;border:2px dashed var(--primary);border-radius:20px;background:repeating-linear-gradient(45deg,#f6fff9,#f6fff9 8px,#effaf3 8px,#effaf3 16px)}.qr-placeholder i{font-size:5rem}.qr-placeholder strong{font-size:.75rem;word-break:break-all}
.print-ticket-body{padding:30px;background:#eef5f1}.print-toolbar{max-width:900px;margin:0 auto 15px;text-align:right}.print-ticket,.group-ticket{max-width:900px;margin:auto;padding:36px;background:#fff;border:1px solid #cfe0d6;border-radius:24px;box-shadow:var(--shadow)}.print-ticket header,.group-ticket header,.print-ticket footer{display:flex;justify-content:space-between;gap:20px}.print-ticket header,.group-ticket header{padding-bottom:20px;border-bottom:3px solid var(--primary)}.ticket-destination{padding:30px 0}.ticket-print-grid{display:grid;grid-template-columns:1fr 250px;gap:30px}.ticket-print-grid>div:first-child{display:grid;gap:6px}.ticket-print-grid small{margin-top:10px;color:var(--muted)}.print-ticket footer{margin-top:28px;padding-top:18px;border-top:1px dashed #aaa;font-size:.8rem}.ticket-terms{padding:14px;background:#f3faf6;border-radius:12px;font-size:.8rem}.group-ticket h1{margin:28px 0 8px}.group-ticket footer{margin-top:25px;text-align:center;color:#667}
@media(max-width:900px){.ticket-checkout-grid,.profile-layout{grid-template-columns:1fr}.ticket-order-card,.profile-layout aside{position:static}.ticket-admin-detail{grid-template-columns:1fr}.footer-cta,.member-footer{align-items:flex-start;flex-direction:column}.wallet-ticket{grid-template-columns:1fr}.wallet-ticket:after{display:none}}@media(max-width:600px){.ticket-buy-card{align-items:flex-start;flex-direction:column;padding:24px}.ticket-buy-card .btn{width:100%}.ticket-actions,.footer-cta>div:last-child{width:100%;flex-direction:column}.ticket-actions .btn,.footer-cta .btn{width:100%}.participant-ticket-list article{grid-template-columns:46px 1fr}.participant-ticket-list article>.badge,.participant-ticket-list article>.btn{grid-column:2}.member-footer nav{flex-wrap:wrap}.ticket-print-grid{grid-template-columns:1fr}.print-ticket,.group-ticket{padding:20px 14px}.print-ticket header,.print-ticket footer{flex-direction:column}}
@media print{.print-toolbar{display:none!important}.print-ticket-body{padding:0;background:#fff}.print-ticket,.group-ticket{max-width:none;margin:0;border:0;border-radius:0;box-shadow:none}.member-footer{display:none!important}@page{size:A4;margin:12mm}}
.payment-upload-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.payment-upload-grid .section-head small{display:block;color:var(--muted)}@media(max-width:750px){.payment-upload-grid{grid-template-columns:1fr}}
.member-hero{display:flex;align-items:center;justify-content:space-between;gap:25px;margin-bottom:18px;padding:30px;border-radius:28px;background:radial-gradient(circle at 90% 10%,rgba(255,209,102,.35),transparent 25%),linear-gradient(135deg,#eafff2,#e8f9ff)}.member-profile-mini{display:flex;align-items:center;gap:18px}.member-profile-mini img{width:76px;height:76px;object-fit:cover;border:5px solid #fff;border-radius:22px;box-shadow:var(--shadow-sm)}.member-profile-mini h2,.member-profile-mini p{margin-bottom:4px}.profile-completion-banner{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:22px;padding:15px 20px;background:#fff;border:1px solid var(--line);border-radius:17px}.profile-completion-banner>div{flex:1}.profile-completion-banner .progress{max-width:500px}.member-shortcuts{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:28px}.member-shortcuts a{display:flex;flex-direction:column;gap:10px;padding:17px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);transition:.2s}.member-shortcuts a:hover{transform:translateY(-3px)}.member-shortcuts span{width:43px;height:43px;display:grid;place-items:center;border-radius:14px;color:var(--primary-dark);background:var(--primary-soft);font-size:1.15rem}.member-shortcuts strong{font-size:.82rem}.member-help-cta{display:flex;align-items:center;gap:18px;margin-top:24px;padding:24px;border-radius:22px;background:linear-gradient(135deg,#edfff5,#fff8e7)}.member-help-cta>i{font-size:2.3rem;color:var(--primary)}.member-help-cta div{flex:1}.member-help-cta h3,.member-help-cta p{margin:0}@media(max-width:900px){.member-shortcuts{grid-template-columns:repeat(3,1fr)}}@media(max-width:600px){.member-hero,.member-help-cta,.profile-completion-banner{align-items:flex-start;flex-direction:column}.member-hero .btn,.member-help-cta .btn{width:100%}.member-shortcuts{grid-template-columns:repeat(2,1fr)}}

/* Premium engagement, scanner and trust layer */
.card{position:relative}.wishlist-button{position:absolute;top:14px;right:14px;z-index:4;width:44px;height:44px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.8);border-radius:50%;color:#5e756b;background:rgba(255,255,255,.9);box-shadow:var(--shadow-sm);backdrop-filter:blur(8px)}.wishlist-button.active{color:#ef5b6b;background:#fff0f3}.page-header>.wishlist-button{position:static;margin-top:12px}.review-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:17px;margin:20px 0}.review-card{padding:22px;background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-sm)}.review-card>img{width:100%;height:180px;object-fit:cover;margin:12px 0;border-radius:14px}.review-card small{display:block;color:var(--muted)}.stars{color:#f6af25;letter-spacing:.08em}.public-reviews{margin-top:55px}.custom-trip-hero{display:grid;grid-template-columns:1.3fr .7fr;align-items:center;gap:35px;margin-bottom:28px;padding:42px;border-radius:30px;background:radial-gradient(circle at 90% 10%,rgba(255,209,102,.35),transparent 30%),linear-gradient(135deg,#edfff5,#e7f8ff)}.trip-style-cloud{display:flex;flex-wrap:wrap;gap:10px}.trip-style-cloud span,.choice-row label{padding:11px 14px;border:1px solid #cde7d8;border-radius:999px;background:rgba(255,255,255,.8);font-weight:700}.choice-row{display:flex;flex-wrap:wrap;gap:12px;margin:14px 0 20px}.custom-trip-form{max-width:1000px;margin:auto}.custom-request-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.custom-request-grid small,.manifest-page td small{display:block;color:var(--muted)}.scanner-card{max-width:760px;margin:auto;padding:25px;background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow)}.scanner-frame{position:relative;overflow:hidden;aspect-ratio:4/3;border-radius:22px;background:#0d241c}.scanner-frame video{width:100%;height:100%;object-fit:cover}.scanner-frame:before,.scanner-frame:after,.scanner-frame>span:before,.scanner-frame>span:after{content:"";position:absolute;width:58px;height:58px;border-color:var(--yellow);border-style:solid}.scanner-frame:before{left:10%;top:10%;border-width:4px 0 0 4px}.scanner-frame:after{right:10%;top:10%;border-width:4px 4px 0 0}.scanner-frame>span:before{left:10%;bottom:10%;border-width:0 0 4px 4px}.scanner-frame>span:after{right:10%;bottom:10%;border-width:0 4px 4px 0}.scanner-actions{text-align:center;padding-top:20px}.real-qr{width:190px;height:190px;object-fit:contain}.manifest-head{display:flex;justify-content:space-between;padding:18px;background:#fff;border:1px solid var(--line);border-radius:15px 15px 0 0}.monthly-bars{display:grid;gap:13px}.monthly-bars>div{display:grid;grid-template-columns:80px 1fr 150px;align-items:center;gap:12px}.monthly-bars i{display:block;height:14px;border-radius:8px;background:linear-gradient(90deg,var(--primary),var(--sea))}.mood-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}.mood-grid a{display:flex;align-items:center;gap:12px;padding:18px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm)}.mood-grid span{width:43px;height:43px;display:grid;place-items:center;border-radius:14px;color:var(--primary-dark);background:var(--primary-soft)}.roadtrip-card{display:grid;grid-template-columns:1fr 1fr;align-items:center;overflow:hidden;padding:0;border-radius:30px;background:linear-gradient(135deg,#eafff2,#e9f9ff);box-shadow:var(--shadow)}.roadtrip-card>div{padding:45px}.roadtrip-card img{width:100%;height:100%;min-height:390px;object-fit:cover}.booking-how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}.booking-how-grid article{padding:24px;background:#fff;border:1px solid var(--line);border-radius:20px}.booking-how-grid span{width:42px;height:42px;display:grid;place-items:center;margin-bottom:15px;border-radius:50%;color:#fff;background:var(--primary);font-weight:800}.guarantee-section{background:linear-gradient(180deg,#f6fff9,#edfaff)}.guarantee-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.guarantee-grid>div{display:flex;align-items:center;gap:12px;padding:18px;background:#fff;border:1px solid var(--line);border-radius:17px}.guarantee-grid i{color:var(--primary);font-size:1.3rem}.trust-links{display:flex;justify-content:center;flex-wrap:wrap;gap:20px;margin-top:28px;font-weight:700}
@media(max-width:1000px){.mood-grid{grid-template-columns:repeat(3,1fr)}.review-grid,.guarantee-grid{grid-template-columns:repeat(2,1fr)}.booking-how-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:700px){.custom-trip-hero,.roadtrip-card{grid-template-columns:1fr}.custom-request-grid,.review-grid,.guarantee-grid{grid-template-columns:1fr}.roadtrip-card img{min-height:250px}.mood-grid{grid-template-columns:repeat(2,1fr)}.booking-how-grid{grid-template-columns:1fr}.monthly-bars>div{grid-template-columns:65px 1fr}.monthly-bars strong{grid-column:2}.manifest-head{align-items:flex-start;flex-direction:column}.no-print{display:grid}}
@media print{.no-print,.admin-sidebar,.admin-topbar,.admin-footer,.page-title-row .btn{display:none!important}.manifest-page{max-width:none!important}.manifest-page .table-wrap{overflow:visible}.manifest-page table{font-size:10px}}

/* TravelJLS marketplace and Partner Hub */
.vendor-sidebar{background:linear-gradient(180deg,#123f56,#0c3244)}.vendor-business-mini{margin-bottom:12px;padding:14px;border-radius:15px;background:rgba(255,255,255,.08)}.vendor-business-mini strong,.vendor-business-mini small{display:block}.vendor-business-mini small{color:rgba(255,255,255,.58)}.vendor-welcome{display:flex;align-items:center;justify-content:space-between;gap:22px;margin-bottom:22px;padding:30px;border-radius:26px;background:radial-gradient(circle at 90% 10%,rgba(255,209,102,.35),transparent 25%),linear-gradient(135deg,#e8f8ff,#ecfff4)}.vendor-register-hero{display:grid;grid-template-columns:1.2fr .8fr;align-items:center;gap:30px;margin-bottom:25px;padding:40px;border-radius:30px;background:linear-gradient(135deg,#e9fff3,#e8f8ff)}.vendor-register-form{max-width:1100px;margin:auto}.vendor-login-visual{background:linear-gradient(rgba(8,56,76,.75),rgba(8,56,76,.88)),url('../img/travel/transport-shuttle.png') center/cover}.vendor-admin-grid,.settlement-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.vendor-card-head{display:flex;align-items:center;gap:15px}.vendor-card-head img{width:70px;height:70px;object-fit:cover;border-radius:18px}.vendor-card-head h3,.vendor-card-head p{margin:0}.vendor-public-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.vendor-public-card{padding:22px;background:#fff;border:1px solid var(--line);border-radius:23px;box-shadow:var(--shadow-sm)}.vendor-public-card>img{width:76px;height:76px;object-fit:cover;margin-bottom:15px;border-radius:19px}.vendor-detail-hero{display:flex;align-items:center;gap:28px;margin-bottom:45px;padding:35px;border-radius:28px;background:linear-gradient(135deg,#eafff2,#e8f8ff)}.vendor-detail-hero>img{width:130px;height:130px;object-fit:cover;border:7px solid #fff;border-radius:28px;box-shadow:var(--shadow-sm)}.vendor-detail-hero h1{margin:10px 0}.vendor-body .stat-card .value{font-size:clamp(1.25rem,2vw,2rem)}
@media(max-width:900px){.vendor-register-hero{grid-template-columns:1fr}.vendor-public-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:650px){.vendor-welcome,.vendor-detail-hero{align-items:flex-start;flex-direction:column}.vendor-welcome .btn{width:100%}.vendor-admin-grid,.settlement-grid,.vendor-public-grid{grid-template-columns:1fr}.vendor-detail-hero>img{width:95px;height:95px}}
.grouped-sidebar{padding-inline:11px}.nav-group{margin:5px 0}.nav-group-toggle{width:100%;display:grid;grid-template-columns:22px 1fr 16px;align-items:center;gap:10px;padding:10px 12px;border:0;border-radius:12px;color:rgba(255,255,255,.68);background:transparent;text-align:left;font-size:.82rem;font-weight:700}.nav-group-toggle:hover,.nav-group.open>.nav-group-toggle{color:#fff;background:rgba(255,255,255,.08)}.nav-group-toggle .bi-chevron-down{font-size:.72rem;transition:.2s}.nav-group.open .nav-group-toggle .bi-chevron-down{transform:rotate(180deg)}.nav-group-items{display:none;padding:3px 0 5px 14px}.nav-group.open .nav-group-items{display:block}.nav-group-items a{padding:8px 10px!important;font-size:.78rem!important}.nav-group-items a i{font-size:.9rem!important}.finance-kpi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:15px;margin-bottom:22px}.report-page .table-wrap small{display:block;color:var(--muted)}.report-page code{padding:4px 7px;border-radius:7px;color:#6b3eb1;background:#f1ebff}.role-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.permission-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}.permission-grid>h3{grid-column:1/-1;margin:18px 0 3px;padding-bottom:9px;border-bottom:1px solid var(--line)}.permission-grid>label{display:flex;gap:10px;padding:13px;background:#fff;border:1px solid var(--line);border-radius:13px}.permission-grid small{display:block;color:var(--muted)}.audit-json{overflow:auto;padding:16px;border-radius:14px;color:#d8f5e4;background:#12372a;white-space:pre-wrap}.report-page .page-title-row{padding-bottom:15px;border-bottom:1px solid var(--line)}@media(max-width:1000px){.finance-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:650px){.finance-kpi-grid,.permission-grid,.role-grid{grid-template-columns:1fr}.nav-group-items{padding-left:8px}}
