*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.loading-screen{color:#4c1d95;background:linear-gradient(145deg,#dbeafe 0%,#ede9fe 35%,#fce7f3 65%,#d1fae5 100%);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.spinner{border:3px solid #fff6;border-top-color:#7c3aed;border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-wrapper{background:linear-gradient(135deg,#c9f0ff 0%,#a78bfa 40%,#f0abfc 80%,#bbf7d0 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.login-wrapper:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff59 0%,#0000 70%);border-radius:50%;width:420px;height:420px;position:absolute;top:-100px;left:-80px}.login-wrapper:after{content:"";pointer-events:none;background:radial-gradient(circle,#a78bfa47 0%,#0000 70%);border-radius:50%;width:320px;height:320px;position:absolute;bottom:-60px;right:-40px}.login-card{-webkit-backdrop-filter:blur(28px)saturate(1.6);text-align:center;z-index:1;background:#ffffff38;border:1px solid #ffffff8c;border-radius:28px;width:100%;max-width:400px;padding:44px 36px 36px;animation:.4s slideUp;position:relative;box-shadow:0 8px 32px #7850c82e,inset 0 1.5px #ffffffb3,inset 0 -1px #ffffff26}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-icon{background:#ffffff73;border:1px solid #ffffffb3;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;display:flex;box-shadow:0 4px 16px #7850c826}.login-icon svg{width:30px;height:30px}.login-badge{color:#321450b3;background:#fff6;border:1px solid #ffffff8c;border-radius:100px;align-items:center;gap:6px;margin-bottom:16px;padding:4px 14px;font-size:12px;font-weight:500;display:inline-flex}.login-badge-dot{background:#22c55e;border-radius:50%;width:6px;height:6px;box-shadow:0 0 0 3px #22c55e40}.login-card h1{color:#1a0a2e;letter-spacing:-.5px;margin:0 0 6px;font-size:26px;font-weight:700}.subtitle{color:#32145099;margin:0 0 24px;font-size:14px}.login-divider{align-items:center;gap:12px;margin-bottom:20px;display:flex}.login-divider-line{background:#ffffff80;flex:1;height:1px}.login-divider-text{color:#32145073;letter-spacing:.08em;font-size:11px;font-weight:600}.error-box{color:#7f1d1d;text-align:left;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fecaca80;border:1px solid #fca5a599;border-radius:12px;margin-bottom:20px;padding:12px 16px;font-size:14px}.google-btn{cursor:pointer;color:#1a0a2e;background:#ffffff8c;border:1px solid #fff9;border-radius:16px;width:100%;margin-bottom:20px;padding:14px 20px;font-size:15px;font-weight:600;transition:all .2s;box-shadow:0 2px 8px #7850c81a,inset 0 1px #fffc}.google-btn:hover:not(:disabled){background:#ffffffb8;border-color:#ffffffd9;transform:translateY(-1px);box-shadow:0 6px 20px #7850c833,inset 0 1px #ffffffe6}.google-btn:active:not(:disabled){transform:translateY(0)}.google-btn:disabled{opacity:.65;cursor:not-allowed}.btn-content{justify-content:center;align-items:center;gap:10px;display:flex}.google-icon{flex-shrink:0;width:20px;height:20px}.btn-loading{color:#32145099;justify-content:center;align-items:center;gap:10px;display:flex}.mini-spinner{border:2px solid #ffffff80;border-top-color:#7c3aed;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}.login-note{color:#32145080;margin:0;font-size:12.5px;line-height:1.6}.dashboard-wrapper{background:linear-gradient(145deg,#ecfdf5 0%,#d1fae5 25%,#dbeafe 55%,#ede9fe 80%,#fce7f3 100%) fixed;min-height:100vh;position:relative;overflow-x:hidden}.dashboard-wrapper:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle,#10b98133 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:fixed;top:-120px;left:-100px}.dashboard-wrapper:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle,#6366f12e 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:fixed;bottom:-80px;right:-60px}.dashboard-container{z-index:1;max-width:800px;margin:0 auto;padding:0 20px 48px;position:relative}.glass{-webkit-backdrop-filter:blur(20px)saturate(180%)!important;background:#ffffff4d!important;border:1px solid #ffffffa6!important;box-shadow:0 8px 32px #10643c1a,inset 0 1.5px #fffc!important}.dash-header{justify-content:space-between;align-items:center;margin-bottom:16px;padding:20px 0 16px;display:flex}.dash-brand{color:#064e3b;align-items:center;gap:8px;font-size:18px;font-weight:700;display:flex}.brand-dot{background:linear-gradient(135deg,#10b981,#6366f1);border-radius:50%;width:10px;height:10px;display:inline-block}.logout-btn{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#065f46;cursor:pointer;background:#ffffff73;border:1px solid #ffffffa6;border-radius:12px;align-items:center;gap:6px;width:auto;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.logout-btn svg{width:15px;height:15px}.logout-btn:hover{color:#991b1b;background:#fee2e299;border-color:#fca5a599}.hero-banner{border-radius:24px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;padding:28px 24px;animation:.5s fadeUp;display:flex}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.hero-content{flex:1;align-items:flex-start;gap:16px;display:flex}.hero-emoji{flex-shrink:0;font-size:44px;line-height:1}.hero-title{color:#064e3b;margin:0 0 4px;font-size:22px;font-weight:800}.hero-subtitle{color:#064e3ba6;margin:0 0 12px;font-size:13.5px}.hero-stats{flex-wrap:wrap;gap:8px;display:flex}.stat-pill{color:#065f46;background:#10b98126;border:1px solid #10b9814d;border-radius:100px;padding:4px 12px;font-size:12px;font-weight:600}.user-chip{background:#ffffff73;border:1px solid #ffffffb3;border-radius:16px;flex-shrink:0;align-items:center;gap:10px;padding:10px 14px;display:flex}.chip-avatar{object-fit:cover;border:2px solid #fffc;border-radius:50%;width:38px;height:38px}.chip-avatar-placeholder{color:#065f46;background:#10b98133;border:2px solid #ffffffb3;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;font-weight:700;display:flex}.chip-name{color:#064e3b;font-size:13px;font-weight:600}.chip-sub{color:#064e3b80;font-size:11px}.tab-nav{border-radius:16px;gap:4px;margin-bottom:14px;padding:6px;display:flex}.tab-btn{color:#064e3b99;cursor:pointer;background:0 0;border:none;border-radius:12px;flex:1;padding:9px 12px;font-size:13.5px;font-weight:600;transition:all .2s}.tab-btn:hover{color:#064e3b;background:#fff6}.tab-active{box-shadow:0 2px 12px #10b98126;color:#065f46!important;background:#ffffffb3!important}.section-title{color:#064e3b8c;text-transform:uppercase;letter-spacing:.09em;align-items:center;gap:10px;margin:0 0 10px;font-size:12px;font-weight:700;display:flex}.section-title:after{content:"";background:#fff9;flex:1;height:1px}.filter-bar{border-radius:16px;flex-direction:column;gap:10px;margin-bottom:14px;padding:14px 16px;display:flex}.search-input{color:#064e3b;box-sizing:border-box;background:#ffffff80;border:1px solid #ffffffa6;border-radius:12px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:all .2s}.search-input::placeholder{color:#064e3b66}.search-input:focus{border-color:#10b98180;box-shadow:0 0 0 3px #10b9811a}.kategori-pills{flex-wrap:wrap;gap:6px;display:flex}.pill-btn{color:#064e3ba6;cursor:pointer;background:#ffffff59;border:1px solid #ffffffa6;border-radius:100px;padding:5px 14px;font-size:12px;font-weight:500;transition:all .15s}.pill-btn:hover{background:#ffffff8c}.pill-active{font-weight:600;color:#065f46!important;background:#10b9812e!important;border-color:#10b98173!important}.wisata-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;display:grid}.wisata-card{border-radius:20px;transition:transform .2s;animation:.4s fadeUp;overflow:hidden}.wisata-card:hover{transform:translateY(-2px)}.wisata-header{justify-content:space-between;align-items:flex-start;padding:18px 16px 14px;display:flex}.wisata-emoji{font-size:32px;line-height:1}.wisata-badges{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.badge-kategori{border-radius:100px;padding:3px 10px;font-size:10.5px;font-weight:600}.badge-rating{color:#92400e;background:#fbbf2433;border:1px solid #fbbf2459;border-radius:100px;padding:3px 10px;font-size:11px;font-weight:600}.wisata-body{padding:14px 16px 16px}.wisata-nama{color:#064e3b;margin:0 0 4px;font-size:15px;font-weight:700}.wisata-lokasi{color:#064e3b8c;margin:0 0 8px;font-size:11.5px}.wisata-desc{color:#064e3bb8;margin:0 0 10px;font-size:12.5px;line-height:1.6}.wisata-meta{color:#064e3b8c;flex-wrap:wrap;gap:10px;margin-bottom:12px;font-size:11.5px;display:flex}.wisata-actions{gap:6px;display:flex}.action-btn{cursor:pointer;color:#064e3bb3;background:#ffffff59;border:1px solid #fff9;border-radius:10px;flex:1;padding:7px 10px;font-size:12px;font-weight:600;transition:all .15s}.action-btn:hover{background:#ffffff8c}.btn-visited{color:#065f46!important;background:#10b9812e!important;border-color:#10b98166!important}.action-btn-icon{cursor:pointer;background:#ffffff59;border:1px solid #fff9;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;transition:all .15s;display:flex}.action-btn-icon:hover{background:#ffffff8c}.btn-wishlist-active{background:#ef44441f!important;border-color:#ef44444d!important}.kuliner-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;display:grid}.kuliner-card{text-align:center;border-radius:18px;padding:20px 16px;animation:.4s fadeUp}.kuliner-emoji{margin-bottom:10px;font-size:36px}.kuliner-nama{color:#064e3b;margin:0 0 6px;font-size:15px;font-weight:700}.kuliner-desc{color:#064e3ba6;margin:0;font-size:12.5px;line-height:1.5}.tips-section{border-radius:20px;flex-direction:column;gap:12px;margin-bottom:14px;padding:18px 20px;display:flex}.tip-item{align-items:flex-start;gap:12px;display:flex}.tip-icon{flex-shrink:0;font-size:20px}.tip-text{color:#064e3bcc;padding-top:2px;font-size:13px;line-height:1.5}.comment-section{border-radius:20px;margin-bottom:16px;padding:20px}.comment-input-wrap{align-items:flex-end;gap:10px;margin-bottom:14px;display:flex}.comment-avatar-sm{object-fit:cover;border:2px solid #ffffffbf;border-radius:50%;flex-shrink:0;width:36px;height:36px}.comment-avatar-placeholder-sm{color:#065f46;background:#10b98133;border:2px solid #ffffffa6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.comment-field-wrap{flex-direction:column;flex:1;gap:8px;display:flex}.comment-textarea{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#064e3b;resize:none;box-sizing:border-box;background:#fff6;border:1px solid #ffffffa6;border-radius:14px;outline:none;width:100%;padding:10px 14px;font-family:inherit;font-size:14px;transition:all .2s}.comment-textarea::placeholder{color:#064e3b66}.comment-textarea:focus{background:#ffffff94;border-color:#10b98180;box-shadow:0 0 0 3px #10b9811a}.comment-submit-btn{color:#065f46;cursor:pointer;white-space:nowrap;background:#10b9812e;border:1px solid #10b98173;border-radius:12px;align-self:flex-end;padding:9px 20px;font-size:13px;font-weight:600;transition:all .2s}.comment-submit-btn:hover{background:#10b98147}.comment-submit-btn:disabled{opacity:.5;cursor:not-allowed}.comment-list{flex-direction:column;gap:10px;display:flex}.comment-item{gap:10px;animation:.3s fadeUp;display:flex}.comment-body{background:#ffffff61;border:1px solid #ffffffa6;border-radius:14px;flex:1;padding:10px 14px}.comment-meta{align-items:center;gap:8px;margin-bottom:5px;display:flex}.comment-author{color:#064e3b;font-size:13px;font-weight:600}.comment-time{color:#064e3b73;font-size:11px}.comment-text{color:#062e1ed1;margin:0;font-size:13.5px;line-height:1.55}.comment-delete{color:#064e3b4d;cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0;font-size:13px;transition:color .15s}.comment-delete:hover{color:#b91c1c}.comment-empty{text-align:center;color:#064e3b73;padding:20px;font-size:13px}.empty-state{text-align:center;color:#064e3b8c;border-radius:20px;margin-bottom:14px;padding:32px;font-size:14px}.dash-footer{text-align:center;color:#064e3b66;margin-top:8px;font-size:12px}@media (width<=560px){.wisata-grid,.kuliner-grid{grid-template-columns:1fr}.hero-banner{flex-direction:column}.user-chip{width:100%}.comment-input-wrap{flex-wrap:wrap}}
