:root{--ink:#0d2758;--coral:#ff6677;--cream:#f2f4fa;--paper:#fff;--mint:#e5f6f1;--line:#e2e6ef;font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","Noto Sans TC",sans-serif;color:var(--ink);background:var(--cream)}
*{box-sizing:border-box}body{background:var(--cream);color:var(--ink)}

.hero{min-height:390px;padding:max(24px,env(safe-area-inset-top)) 22px 72px;color:white;background:linear-gradient(180deg,rgba(8,32,82,.08),rgba(8,31,79,.86)),url('singapore-journey.svg') center/cover no-repeat;border-radius:0 0 30px 30px;box-shadow:0 12px 34px rgba(12,39,88,.18)}
.hero:before,.hero:after{display:none}.hero__top{position:relative;z-index:2}.hero .eyebrow{opacity:.9;letter-spacing:.13em}.hero .icon-button{display:grid;place-items:center;width:42px;height:42px;padding:0;color:white;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.45);border-radius:14px;backdrop-filter:blur(12px)}
.hero h1{position:relative;z-index:1;margin:72px 0 16px;max-width:300px;font-family:inherit;font-size:48px;font-weight:780;line-height:.98;letter-spacing:-.055em;text-shadow:0 3px 18px rgba(8,27,68,.24)}.hero h1 em{color:white;font-style:normal;font-weight:420}.hero p{position:relative;z-index:1;margin:0;max-width:310px;font-size:13px;line-height:1.5;opacity:.9}.countdown{position:relative;z-index:1;display:inline-flex;margin-top:18px;padding:9px 13px;color:#fff;background:var(--coral);border:0;border-radius:11px;font-size:12px;font-weight:750;box-shadow:0 7px 18px rgba(255,102,119,.28)}

.today-card{margin:-45px 18px 0;padding:21px 20px;color:var(--ink);background:white;border:0;border-radius:20px;box-shadow:0 13px 32px rgba(14,39,88,.14)}.today-card .eyebrow{color:#71809e}.today-card h2{max-width:265px;font-family:inherit;font-size:22px;font-weight:760;letter-spacing:-.025em}.weather{display:flex;align-items:center;gap:4px;color:var(--coral);font-family:inherit;font-size:18px;font-weight:800}

.section{padding:38px 18px 8px}.section-heading{align-items:end}.section h2{margin:5px 0 13px;font-family:inherit;font-size:27px;font-weight:780;letter-spacing:-.035em}.section .eyebrow{color:#8a96ad;font-size:10px}.text-button{margin-bottom:10px;color:var(--coral);font-size:12px;font-weight:750}
.day-carousel{display:grid;grid-template-columns:34px minmax(0,1fr) 34px;align-items:center;gap:5px;margin:0 -7px}.day-tabs{gap:8px;margin:0;padding:4px 5px 12px;scroll-snap-type:x proximity}.day-tab{min-width:55px;height:59px;color:#6d7993;background:white;border:1px solid var(--line);border-radius:14px;box-shadow:0 3px 10px rgba(14,39,88,.05);scroll-snap-align:center}.day-tab b{color:var(--ink);font-size:18px}.day-tab.active{color:white;background:var(--ink);border-color:var(--ink);box-shadow:inset 0 -3px 0 rgba(0,0,0,.16)}.day-tab.active b{color:white}.day-tab.active:after{content:"";display:block;width:18px;height:3px;margin:3px auto 0;background:var(--coral);border-radius:99px}.day-arrow{display:grid;place-items:center;width:32px;height:42px;padding:0;color:var(--ink);background:white;border:1px solid var(--line);border-radius:11px;font-size:25px;box-shadow:0 3px 10px rgba(14,39,88,.06)}.day-arrow:active{color:white;background:var(--ink)}.swipe-hint{margin:0 0 12px;color:#8290a9;text-align:center;font-size:10px}

.itinerary{margin-top:4px;padding:22px 18px;background:white;border:1px solid var(--line);border-radius:20px;box-shadow:0 8px 25px rgba(14,39,88,.07)}.day-hero{padding-bottom:17px}.day-hero h3{font-family:inherit;font-size:25px;font-weight:780;letter-spacing:-.035em}.day-hero p{color:#68758f}.edit-day{padding:8px 12px;color:white;background:var(--ink);border:0;border-radius:11px;font-weight:700}.timeline-item{grid-template-columns:55px 12px 1fr;gap:9px;padding-top:21px}.time{color:var(--coral);font-size:11px}.dot{width:9px;height:9px;margin-top:3px;background:white;border:2px solid var(--coral)}.dot:after{background:#dfe4ed}.place h4{font-size:15px}.place p{color:#63708a;opacity:1}.map-link{margin-top:8px;padding:5px 9px;color:#376aa7;background:#edf4ff;border-radius:8px;font-size:11px;font-weight:700}

.love-note{margin-top:24px;padding:17px;background:#fff2f4;border:1px solid #ffd8de;border-radius:16px}.love-note label{margin:0;color:#b83f55;font-weight:760}.love-note textarea{min-height:82px;background:white;border-color:#f1ccd2}.love-note small{display:block;margin-top:7px;color:#8a7280}

.essentials{margin-top:32px;padding-bottom:43px;background:#e9edf6;border-radius:28px 28px 0 0}.quick-grid{gap:10px}.quick-grid a,.quick-grid button{min-height:68px;padding:14px;background:white;border:1px solid var(--line);border-radius:15px;box-shadow:0 5px 14px rgba(14,39,88,.05)}.quick-grid b{width:32px;height:32px;background:#edf2ff;color:var(--ink)}.quick-grid span{font-size:12px}.tips{border-color:#d6dce8}.tips p{color:#52617e;border-color:#d6dce8}

dialog{max-height:calc(100dvh - 28px);overflow:auto;background:#f8f9fc;border:0;border-radius:24px;box-shadow:0 24px 70px rgba(7,27,68,.28)}dialog::backdrop{background:rgba(5,22,56,.58);backdrop-filter:blur(5px)}.dialog-head h2{font-family:inherit;font-weight:780}.primary{min-height:50px;color:white;background:var(--coral);border:0;border-radius:13px;font-weight:780;box-shadow:0 8px 20px rgba(255,102,119,.22)}input,textarea{border:1px solid #dce2ec;border-radius:12px;background:white}.checklist label{background:white;border:1px solid var(--line)}

.form-label{font-size:12px;font-weight:800;margin:18px 0 9px}.edit-items{display:grid;gap:13px}.edit-item-row{padding:14px;background:white;border:1px solid var(--line);border-radius:16px;box-shadow:0 5px 15px rgba(14,39,88,.05)}.edit-item-head{display:flex;align-items:center;justify-content:space-between}.edit-item-number{font-size:13px}.remove-item{padding:6px 9px;color:#c24158;background:#fff0f3;border:0;border-radius:8px;font-size:11px;font-weight:750}.edit-item-grid{display:grid;grid-template-columns:96px 1fr;gap:8px}.edit-item-row label{margin:8px 0 0}.edit-item-row input,.edit-item-row textarea{margin-top:5px}.add-item{width:100%;margin:15px 0 3px;padding:13px;color:#315f9a;background:#eef5ff;border:1px dashed #8ba9ce;border-radius:13px;font-weight:750}

.bottom-nav{height:76px;color:#8b96ab;background:rgba(255,255,255,.94);border-top:1px solid var(--line);box-shadow:0 -7px 25px rgba(14,39,88,.06)}.bottom-nav button,.bottom-nav a{font-size:18px}.bottom-nav a{flex:1;border:0;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:inherit;text-decoration:none;opacity:.48}.bottom-nav button.active,.bottom-nav a.active{color:var(--coral);opacity:1}.bottom-nav a span{font-size:10px}

.packing-body{min-height:100dvh;background:#f3f5f1}.packing-hero{position:relative;overflow:hidden;padding:max(22px,env(safe-area-inset-top)) 20px 28px;color:white;background:linear-gradient(145deg,#153f38 0%,#28695f 72%,#e8a781 160%);border-radius:0 0 30px 30px;box-shadow:0 14px 34px rgba(18,63,56,.18)}.packing-hero:after{content:"";position:absolute;right:-46px;top:72px;width:180px;height:180px;border:34px solid rgba(255,255,255,.08);border-radius:50%}.packing-top{position:relative;z-index:1;display:grid;grid-template-columns:42px 1fr 42px;align-items:center;text-align:center}.packing-top>a{display:grid;place-items:center;width:40px;height:40px;color:white;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);border-radius:13px;text-decoration:none;font-size:32px;line-height:1}.packing-hero h1{position:relative;z-index:1;margin:38px 0 12px;font-size:43px;line-height:1.02;letter-spacing:-.055em}.packing-hero>p{position:relative;z-index:1;max-width:310px;margin:0;color:rgba(255,255,255,.78);font-size:13px;line-height:1.6}.packing-progress{position:relative;z-index:1;margin-top:24px;padding:16px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:17px;backdrop-filter:blur(9px)}.packing-progress>div:first-child{display:flex;align-items:baseline;justify-content:space-between}.packing-progress strong{font-size:21px}.packing-progress span{font-size:11px;opacity:.72}.progress-track{height:7px;margin-top:11px;overflow:hidden;background:rgba(255,255,255,.18);border-radius:99px}.progress-track i{display:block;width:0;height:100%;background:#ff8a91;border-radius:99px;transition:width .3s ease}.packing-content{padding:34px 18px 130px}.packing-toolbar{display:flex;align-items:end;justify-content:space-between;margin-bottom:17px}.packing-toolbar h2{margin:5px 0 0;font-size:25px;letter-spacing:-.04em}.packing-toolbar .eyebrow{color:#82908b}.soft-button{padding:9px 11px;color:#6e7d78;background:white;border:1px solid var(--line);border-radius:11px;font-size:11px;font-weight:750}.packing-groups{display:grid;gap:14px}.packing-group{overflow:hidden;background:white;border:1px solid rgba(20,63,56,.1);border-radius:19px;box-shadow:0 7px 22px rgba(20,63,56,.055)}.packing-group>header{display:flex;align-items:center;gap:10px;padding:15px 16px 11px}.packing-group>header>span{display:grid;place-items:center;width:31px;height:31px;color:#1d5a51;background:#eaf4ef;border-radius:10px;font-weight:800}.packing-group h3{margin:0;font-size:15px}.packing-item{position:relative;display:grid;grid-template-columns:25px 1fr auto;align-items:center;gap:10px;min-height:48px;margin:0 16px;padding:8px 0;border-top:1px solid #edf0ec;font-size:14px}.packing-item input{position:absolute;width:1px;height:1px;opacity:0}.packing-item>i{display:grid;place-items:center;width:23px;height:23px;color:transparent;background:#f7f8f5;border:1px solid #d6ddd8;border-radius:8px;font-style:normal;font-size:13px}.packing-item.checked>i{color:white;background:#ff6b7b;border-color:#ff6b7b}.packing-item.checked>span{color:#94a09c;text-decoration:line-through}.remove-pack{width:28px;height:28px;padding:0;color:#a7afac;background:transparent;border:0;font-size:20px}.custom-packing{margin-top:20px;padding:17px;background:#fff4f4;border:1px solid #ffdfe2;border-radius:18px}.custom-packing>label{margin:0 0 10px;color:#a24551;font-size:13px}.custom-packing>div{display:grid;grid-template-columns:1fr auto;gap:8px}.custom-packing input{margin:0;background:white}.custom-packing button{padding:0 14px;color:white;background:#ff6b7b;border:0;border-radius:11px;font-size:12px;font-weight:800}.packing-note{margin-top:14px;padding:14px;color:#66736e;background:#e6ece8;border-radius:14px;font-size:12px;line-height:1.6}

@media(max-width:600px){dialog{width:100vw;max-width:none;height:100dvh;max-height:100dvh;margin:0;border-radius:0;box-shadow:none}dialog form{min-height:100%;padding:0 18px calc(94px + env(safe-area-inset-bottom))}.dialog-head{position:sticky;top:0;z-index:3;margin:0 -18px 10px;padding:max(18px,env(safe-area-inset-top)) 18px 10px;background:rgba(248,249,252,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(14px)}.dialog-head h2{margin-bottom:8px}dialog .primary{position:sticky;z-index:3;bottom:calc(12px + env(safe-area-inset-bottom));margin-top:20px}#settingsForm>label{padding:13px;margin:9px 0;background:white;border:1px solid var(--line);border-radius:15px}#settingsForm>label input,#settingsForm>label textarea{background:#f8f9fc}input,textarea{font-size:16px}}
@media(max-width:370px){.hero h1{font-size:43px}.today-card{margin-left:13px;margin-right:13px}.section{padding-left:15px;padding-right:15px}}

.custom-packing select{display:block;width:100%;margin:0 0 9px;padding:12px 38px 12px 13px;color:var(--ink);background:white;border:1px solid #f0cfd3;border-radius:11px;font:inherit;font-size:14px}.original-time{display:block;margin-top:5px;color:#8792a6;font-size:10px;font-weight:600}.edit-item-grid{grid-template-columns:minmax(112px,.42fr) 1fr}.edit-item-row input[type="time"]{min-height:47px;padding-left:10px;padding-right:7px;color:var(--ink);background:#fff}

.sync-card{margin:0 0 18px;padding:17px;background:#173f39;color:white;border-radius:19px;box-shadow:0 9px 24px rgba(20,63,56,.16)}.sync-card-head{display:flex;align-items:center;justify-content:space-between}.sync-card h3{margin:4px 0 0;font-size:18px}.sync-card .eyebrow{color:#9fd0c4}.sync-card>p{margin:12px 0;color:rgba(255,255,255,.74);font-size:12px;line-height:1.55}.sync-card>label{margin:0 0 6px;color:rgba(255,255,255,.7);font-size:11px}.sync-card>input{margin:0;color:#173f39;background:white;border:0;text-transform:uppercase;letter-spacing:.04em}.sync-card>small{display:block;margin-top:10px;color:rgba(255,255,255,.56);font-size:10px;line-height:1.45}.sync-status{padding:6px 9px;color:#dce9e5;background:rgba(255,255,255,.1);border-radius:99px;font-size:10px;font-weight:750}.sync-status[data-state="ok"]{color:#17433a;background:#bdebdc}.sync-status[data-state="error"]{color:#7a2430;background:#ffd8de}.sync-actions{display:grid;grid-template-columns:1.25fr 1fr .65fr;gap:7px;margin-top:9px}.sync-actions button{min-height:38px;padding:7px;color:white;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:10px;font-size:11px;font-weight:750}.sync-actions button:first-child{color:#173f39;background:#fff;border-color:#fff}

.module-body{min-height:100dvh;background:#f4f6fa}.module-hero{padding:max(24px,env(safe-area-inset-top)) 20px 29px;color:white;border-radius:0 0 30px 30px}.module-hero.blue{background:linear-gradient(145deg,#244f88,#5e88bd)}.module-hero.rose{background:linear-gradient(145deg,#8d3f53,#d87983)}.module-hero>a{display:grid;place-items:center;width:40px;height:40px;color:white;background:#ffffff22;border:1px solid #ffffff44;border-radius:13px;text-decoration:none;font-size:31px}.module-hero>.eyebrow{display:block;margin-top:28px}.module-hero h1{margin:6px 0 8px;font-size:38px}.module-hero p{margin:0 0 16px;color:#ffffffc4;font-size:13px}.module-content{padding:28px 18px 120px}.segment{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;padding:4px;background:#e7ebf1;border-radius:14px}.segment button{min-height:40px;color:#748096;background:transparent;border:0;border-radius:11px;font-weight:750}.segment button.active{color:var(--ink);background:white;box-shadow:0 3px 9px #14284614}.inline-form{display:grid;grid-template-columns:1fr 48px;gap:8px;margin:15px 0}.inline-form input{margin:0}.inline-form button{color:white;background:var(--coral);border:0;border-radius:12px;font-size:22px}.simple-list{display:grid;gap:9px}.simple-item{display:grid;grid-template-columns:25px 1fr 28px;align-items:center;gap:10px;min-height:54px;margin:0;padding:9px 13px;background:white;border:1px solid var(--line);border-radius:15px}.simple-item input{position:absolute;opacity:0}.simple-item i{display:grid;place-items:center;width:23px;height:23px;color:transparent;border:1px solid #d5dbe4;border-radius:8px;font-style:normal}.simple-item.done i{color:white;background:var(--coral)}.simple-item.done span{text-decoration:line-through;opacity:.5}.simple-item button,.record-list button,.journal-list button{color:#a4acb9;background:transparent;border:0;font-size:19px}.empty-state{padding:34px 20px;color:#8b96a8;background:white;border:1px dashed #ccd3df;border-radius:17px;text-align:center}.rate-card{display:grid;grid-template-columns:1fr auto;gap:10px;margin-bottom:17px;padding:17px;color:white;background:#173f39;border-radius:19px}.rate-card strong,.rate-card small{display:block}.rate-card strong{margin:5px 0;font-size:22px}.rate-card small{color:#ffffffa1;font-size:10px}.rate-card>button{align-self:start;padding:8px 11px;color:white;background:#ffffff22;border:1px solid #ffffff33;border-radius:10px}.rate-card>label{grid-column:1/-1;margin:0;color:#ffffffb3}.rate-card input{margin-top:5px;color:var(--ink)}.total-card{margin:15px 0;padding:18px;background:#fff0f2;border:1px solid #ffd8de;border-radius:17px}.total-card span,.total-card small{display:block;color:#9b6670}.total-card strong{display:block;margin:5px 0;color:#923e50;font-size:20px}.record-form{margin:12px 0;padding:16px;background:white;border:1px solid var(--line);border-radius:18px}.record-form>div{display:grid;grid-template-columns:1fr 1fr;gap:9px}.record-form select{display:block;width:100%;margin-top:7px;padding:13px;background:white;border:1px solid var(--line);border-radius:12px;font:inherit}.record-list,.journal-list{display:grid;gap:9px}.record-list article{display:grid;grid-template-columns:1fr auto 25px;align-items:center;gap:8px;padding:14px;background:white;border:1px solid var(--line);border-radius:15px}.record-list small{display:block;color:#8a95a6}.journal-list article{padding:16px;background:white;border:1px solid var(--line);border-radius:16px}.journal-list header{display:grid;grid-template-columns:1fr auto 25px}.journal-list p{line-height:1.65}
.rate-note{grid-column:1/-1;margin:0;color:#ffffffa6;font-size:10px;line-height:1.5}
