@import"https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700&family=Plus+Jakarta+Sans:wght@600;700;800&display=swap";:root{--bg-base: #f5efe7;--bg-surface: rgba(255, 251, 247, .94);--bg-soft: #efe5d9;--bg-soft-strong: #e7dac8;--brand-primary: #165c52;--brand-primary-soft: #d9ede8;--brand-accent: #c4632b;--brand-accent-soft: #ffe7d8;--info-blue: #2b68ad;--info-blue-soft: #e8f0fb;--text-primary: #221a14;--text-secondary: #65584c;--text-tertiary: #908173;--line-soft: rgba(70, 51, 33, .12);--line-strong: rgba(70, 51, 33, .18);--danger: #ae432c;--shadow: 0 12px 28px rgba(62, 43, 25, .08);--shadow-soft: 0 6px 18px rgba(62, 43, 25, .05);--radius-panel: 24px;--radius-card: 12px;--radius-pill: 999px;--radius-card-strong: 13px;--radius-card-regular: 10px;--radius-feature-card: var(--radius-card-strong);--radius-list-card: var(--radius-card-regular);--radius-media-strong: 8px;--radius-media-regular: 7px;--radius-feature-media: var(--radius-media-strong);--radius-thumb: var(--radius-media-regular);--radius-chip: 6px;--radius-icon-button: 999px;--card-padding-strong: 13px;--card-padding-regular: 12px;--card-row-gap-strong: 10px;--card-row-gap-regular: 8px;--card-body-gap: 5px;--card-copy-gap-strong: 6px;--card-copy-gap-regular: 5px;--card-meta-gap: 8px;--card-meta-gap-strong: 9px;--card-meta-gap-regular: 8px;--weather-plane-radius: 10px;--compact-thumb-width: 130px;--compact-thumb-height: 98px;--content-max: 1100px;--sheet-max: 760px;--tabbar-max: 920px;--layout-gutter: clamp(16px, 3.8vw, 32px);--page-inline: max(var(--layout-gutter), calc((100vw - var(--content-max)) / 2 + var(--layout-gutter)));--top-safe: env(safe-area-inset-top, 0px);--bottom-safe: env(safe-area-inset-bottom, 0px);--bg: var(--bg-base);--bg-strong: var(--bg-soft-strong);--surface: var(--bg-surface);--surface-strong: #fffaf5;--surface-soft: var(--bg-soft);--surface-muted: var(--bg-soft-strong);--text: var(--text-primary);--text-soft: var(--text-secondary);--text-faint: var(--text-tertiary);--line: var(--line-soft);--primary: var(--brand-primary);--primary-soft: var(--brand-primary-soft);--accent: var(--brand-accent);--accent-soft: var(--brand-accent-soft)}*{box-sizing:border-box}html,body,#root{min-height:100%;width:100%}html{background:var(--bg-base);scrollbar-gutter:stable}body{margin:0;font-family:Be Vietnam Pro,sans-serif;color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,textarea,select{font:inherit;color:inherit}button{border:0;background:transparent;padding:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.48}img{display:block;max-width:100%}h1,h2,h3,h4,strong{margin:0;font-family:Plus Jakarta Sans,sans-serif;letter-spacing:-.03em}p{margin:0}input{width:100%;min-height:48px;border-radius:18px;border:1px solid var(--line-soft);background:var(--bg-surface);padding:0 14px}button:focus-visible,input:focus-visible{outline:3px solid rgba(22,92,82,.24);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-shell{position:relative;width:100%;min-height:100dvh;background:var(--bg-base);padding-bottom:calc(88px + var(--bottom-safe))}.top-app-bar{position:sticky;top:0;z-index:30;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:calc(var(--top-safe) + 14px) var(--page-inline) 14px;background:linear-gradient(180deg,#f5efe7f5,#f5efe7d6 72%,#f5efe700);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.top-app-bar__copy{display:flex;flex-direction:column;gap:4px;min-width:0}.top-app-bar__eyebrow,.eyebrow,.detail-header__eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand-primary)}.top-app-bar__copy strong{font-size:clamp(1.16rem,1vw + .9rem,1.28rem)}.top-app-bar__copy span:last-child{color:var(--text-secondary);font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-app-bar__action,.secondary-button,.primary-button,.filter-button,.section-header__action,.sheet-link-button,.toast__action,.toast__close{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-pill);font-weight:700}.top-app-bar__action,.primary-button{padding:0 16px}.primary-button{background:var(--brand-primary);color:#f6fffc;box-shadow:var(--shadow-soft)}.top-app-bar__action{padding:0 15px;background:var(--brand-primary-soft);color:var(--brand-primary);border:1px solid rgba(22,92,82,.12)}.primary-button--soft{background:var(--brand-primary-soft);color:var(--brand-primary)}.secondary-button,.filter-button,.sheet-link-button,.section-header__action,.toast__action,.toast__close{padding:0 14px;background:var(--bg-soft);color:var(--text-primary);border:1px solid var(--line-soft)}.secondary-button--active{background:var(--brand-accent-soft);color:var(--brand-accent)}.app-shell__main{padding:18px var(--page-inline) calc(148px + var(--bottom-safe))}.app-shell__main--home{padding-top:calc(var(--top-safe) + 16px)}.screen-stack,.stack-list,.surface-section,.control-panel{display:flex;flex-direction:column}.screen-stack{gap:clamp(22px,3vw,30px)}.explore-header{display:flex;flex-direction:column;gap:12px}.explore-search-bar{display:flex;align-items:center;gap:10px}.explore-search-bar--solo{display:block}.explore-search-bar--solo .input-shell{width:100%}.explore-category-chips{display:flex;flex-wrap:nowrap;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.explore-category-chips::-webkit-scrollbar{display:none}.explore-filter-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:10px 12px;border-radius:var(--radius-card-regular);border:1px solid var(--line-soft);background:#fffbf7b8;font-size:.84rem;color:var(--text-secondary);text-align:left;min-height:44px;cursor:pointer;transition:background .14s ease,border-color .14s ease}.explore-filter-summary:hover,.explore-filter-summary:active{background:#fffbf7eb;border-color:#46332129}.explore-filter-summary__text{flex:1;min-width:0}.explore-filter-summary__action{display:inline-flex;align-items:center;gap:5px;flex-shrink:0;font-weight:600;color:var(--text-secondary);font-size:.8rem}.explore-result-count{margin:-4px 0 0;font-size:.86rem;color:var(--text-secondary);padding:0 2px}.explore-feed{margin-top:0}.segmented-row--sheet{flex-wrap:wrap}.chip-grid--compact{gap:6px}.stack-list--tight{gap:8px}.filter-option-section{display:flex;flex-direction:column;gap:10px;min-width:0}.filter-option-section__title{margin:0;font-size:.82rem;font-weight:700;color:var(--text-secondary)}.filter-option-section__body{min-width:0}.filter-chip-group{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start;width:100%}.filter-toggle-list{display:flex;flex-direction:column;border-radius:var(--radius-card-regular);border:1px solid var(--line-soft);overflow:hidden}.filter-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:12px 14px;min-height:48px;background:#fffbf780;border:none;border-bottom:1px solid rgba(70,51,33,.08);text-align:left;cursor:pointer;transition:background .14s ease}.filter-toggle-row:last-child{border-bottom:none}.filter-toggle-row:hover,.filter-toggle-row:focus-visible{background:#fffbf7d9}.filter-toggle-row__label{font-size:.9rem;font-weight:600;color:var(--text-primary);line-height:1.35}.filter-toggle-row.is-on .filter-toggle-row__label{color:var(--brand-primary)}.filter-toggle-row__track{position:relative;width:44px;height:26px;flex-shrink:0;border-radius:999px;background:#46332124;transition:background .16s ease}.filter-toggle-row.is-on .filter-toggle-row__track{background:var(--brand-primary)}.filter-toggle-row__thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #3e2b192e;transition:transform .16s ease}.filter-toggle-row.is-on .filter-toggle-row__thumb{transform:translate(18px)}.filter-sheet-region-footer{display:flex;flex-direction:column;gap:8px;margin-top:4px;padding-top:14px;border-top:1px solid var(--line-soft)}.filter-sheet-region-footer__line{margin:0;font-size:.78rem;color:var(--text-secondary);line-height:1.4}.filter-sheet-region-footer__edit{font-size:.88rem;padding-block:10px}.secondary-button--block{width:100%;justify-content:center}.stack-list{gap:12px}.control-panel,.weather-card,.empty-state-card,.content-card,.collection-card--row,.keyword-card,.reminder-row,.reminder-alert-card{border-radius:var(--radius-panel);background:var(--bg-surface);border:1px solid var(--line-soft);box-shadow:var(--shadow-soft)}.surface-section{gap:14px}.surface-section--compact{gap:10px}.surface-section--hint{padding:14px 16px;border-radius:var(--radius-panel);background:#efe5d9bd;border:1px solid var(--line-soft)}.hint-row{display:flex;align-items:center;gap:10px;color:var(--text-secondary)}.control-panel{gap:14px;padding:16px}.control-panel--soft{background:var(--bg-soft);box-shadow:none}.tab-toolbar{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:22px;background:var(--bg-soft);border:1px solid var(--line-soft)}.tab-toolbar .segmented-row{flex:1;min-width:0}.tab-toolbar__action{flex-shrink:0}.inline-helper{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.9rem}.section-header,.region-group__header,.inline-header,.results-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-header{align-items:flex-start}.section-header__copy{display:flex;flex-direction:column;gap:4px}.section-header__copy h2{font-size:1.08rem}.section-header__copy p{color:var(--text-secondary);font-size:.9rem;line-height:1.45}.home-screen{gap:20px}.home-page-header,.status-inline-panel,.weather-summary-card__header,.weather-summary-card__headline,.feature-content-card__header{display:flex;gap:12px}.home-page-header{align-items:flex-start;justify-content:space-between;gap:16px}.home-page-header__copy{min-width:0;display:flex;flex-direction:column;gap:6px}.home-page-header__copy h1{font-size:clamp(1.5rem,1.5vw + 1.2rem,1.9rem);line-height:1.02;color:var(--text-primary)}.home-page-header__copy p{color:var(--text-secondary);font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-page-header__action{min-height:44px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 15px;border-radius:var(--radius-pill);border:1px solid rgba(22,92,82,.14);background:var(--brand-primary-soft);color:var(--brand-primary);font-weight:700}.status-inline-panel{align-items:center;padding:12px 14px;border-radius:20px;border:1px solid var(--line-soft);background:#efe5d9e6}.status-inline-panel__icon{width:38px;height:38px;border-radius:14px;background:#fffbf7e6;color:var(--brand-primary);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.status-inline-panel__copy{min-width:0;flex:1;display:flex;flex-direction:column;gap:3px}.status-inline-panel__copy strong,.weather-summary-card__copy strong,.feature-content-card__copy h3,.compact-media-card__copy h3{color:var(--text-primary)}.status-inline-panel__copy strong{font-size:.96rem;line-height:1.25}.status-inline-panel__copy p{color:var(--text-secondary);font-size:.84rem;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-inline-panel .secondary-button{flex-shrink:0;background:#fffbf7e6}.weather-summary-card{cursor:pointer;border-radius:var(--radius-card);border:1px solid rgba(43,104,173,.16);background:linear-gradient(180deg,#e8f0fbfa,#f5faffe6),var(--info-blue-soft);box-shadow:var(--shadow-soft);padding:12px}.weather-summary-card:focus-visible{outline:3px solid rgba(43,104,173,.22);outline-offset:3px}.weather-summary-card__header{align-items:center;justify-content:space-between}.weather-summary-card__copy{display:flex;flex-direction:column;gap:3px}.weather-summary-card__copy strong{font-size:1rem}.weather-summary-card__link{min-height:44px;display:inline-flex;align-items:center;gap:4px;color:var(--info-blue);font-weight:700}.weather-summary-card__switcher{display:flex;gap:8px;overflow-x:auto;margin-top:8px;padding-bottom:2px;scrollbar-width:none}.weather-summary-card__switcher::-webkit-scrollbar{display:none}.weather-summary-card__switch{min-height:40px;padding:0 13px;border-radius:var(--radius-pill);border:1px solid rgba(43,104,173,.14);background:#ffffff9e;color:var(--text-secondary);font-weight:700;white-space:nowrap}.weather-summary-card__switch.is-active{background:#2b68ad1f;color:var(--info-blue)}.weather-summary-card__body{width:100%;margin-top:8px;padding:0;text-align:left;transition:transform .14s ease,background-color .14s ease,box-shadow .14s ease}.weather-summary-card__body:hover,.weather-summary-card__body:active{transform:translateY(-1px)}.weather-summary-card__main{display:flex;align-items:center;min-width:0}.weather-summary-card__headline{align-items:baseline;gap:10px;min-width:0}.weather-summary-card__temp{font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(1.85rem,1.5vw + 1.2rem,2.35rem);line-height:.95;flex-shrink:0}.weather-summary-card__headline p{min-width:0;color:var(--text-secondary);font-size:.92rem;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weather-summary-card__stats{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:8px;color:var(--text-secondary);font-size:.8rem;line-height:1.25}.feature-card-grid{display:grid;gap:12px;grid-template-columns:1fr}.feature-content-card,.compact-media-card,.notice-card{--card-row-gap: var(--card-row-gap-regular);--card-copy-gap: var(--card-copy-gap-regular);--card-meta-gap-local: var(--card-meta-gap-regular);position:relative;border-radius:var(--radius-card-regular);border:1px solid var(--line-soft);background:var(--bg-surface);box-shadow:var(--shadow-soft)}.feature-content-card{--card-row-gap: var(--card-row-gap-strong);--card-copy-gap: var(--card-copy-gap-strong);--card-meta-gap-local: var(--card-meta-gap-strong);border-radius:var(--radius-card-strong)}.feature-content-card__tap,.compact-media-card__tap{width:100%;text-align:left;border-radius:inherit;background:transparent;transition:transform .14s ease,box-shadow .14s ease}.feature-content-card__tap:hover,.feature-content-card__tap:active,.compact-media-card__tap:hover,.compact-media-card__tap:active{transform:translateY(-1px)}.feature-content-card__tap{display:flex;flex-direction:column;gap:var(--card-row-gap);padding:var(--card-padding-strong)}.feature-content-card__header{justify-content:flex-start;padding-right:48px}.feature-content-card--none .feature-content-card__copy p{-webkit-line-clamp:3}.feature-content-card--safe .feature-content-card__tap{display:grid;grid-template-columns:minmax(0,1fr) 112px;column-gap:14px;row-gap:var(--card-row-gap)}.feature-content-card--safe .feature-content-card__header,.feature-content-card--safe .card-time-meta{grid-column:1 / -1}.feature-content-card--safe .feature-content-card__copy{grid-column:1 / 2;grid-row:1 / 2}.feature-content-card__safe-media{grid-column:2 / 3;grid-row:1 / 3;align-self:stretch}.feature-content-card--safe .card-time-meta{grid-row:2 / 3}.feature-content-card__copy h3{font-size:1.08rem;line-height:1.32}.feature-content-card__copy p{color:var(--text-secondary);font-size:.93rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.feature-content-card__image{--media-thumb-radius: var(--radius-media-strong);margin-top:0;border-radius:var(--media-thumb-radius);overflow:hidden;aspect-ratio:1.55;background:var(--bg-soft)}.feature-content-card--safe .feature-content-card__image{margin-top:0;aspect-ratio:.9}.feature-content-card .card-bottom-meta-row{margin-top:0}.feature-content-card__save,.compact-media-card__save,.notice-card__control{position:absolute;top:8px;right:8px;z-index:2}.compact-media-card__tap{padding:var(--card-padding-regular)}.compact-media-card__layout,.notice-card--with-media .notice-card__layout{display:grid;grid-template-columns:minmax(0,1fr) var(--compact-thumb-width);column-gap:11px;align-items:stretch}.compact-media-card__stack,.notice-card--with-media .notice-card__stack{min-width:0;min-height:var(--compact-thumb-height);display:flex;flex-direction:column;gap:var(--card-row-gap)}.compact-media-card__copy{padding-right:2px}.compact-media-card__copy h3{font-size:1rem;line-height:1.34}.compact-media-card__copy p{color:var(--text-secondary);font-size:.9rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.compact-media-card__thumb,.notice-card--with-media .notice-card__thumb{--media-thumb-radius: var(--radius-media-regular);width:var(--compact-thumb-width);min-width:var(--compact-thumb-width);height:var(--compact-thumb-height);border-radius:var(--media-thumb-radius);overflow:hidden;background:var(--bg-soft);align-self:start;justify-self:end}.compact-media-card--no-media .compact-media-card__tap{display:block}.compact-media-card--no-media .compact-media-card__layout{grid-template-columns:1fr}.compact-media-card--no-media .compact-media-card__stack{min-height:0}.compact-media-card--no-media .compact-media-card__thumb{display:none}.region-badge{min-height:24px;padding-inline:8px;font-size:.74rem}.meta-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap;color:var(--text-secondary);font-size:.8rem;line-height:1.3}.card-header-row{display:flex;align-items:flex-start;justify-content:flex-start;gap:6px;min-width:0}.card-body-block{min-width:0;display:flex;flex-direction:column;gap:var(--card-copy-gap, var(--card-body-gap))}.card-bottom-meta-row{margin-top:auto;padding-top:var(--card-meta-gap-local, var(--card-meta-gap))}.meta-row__item{display:inline-flex;align-items:center;gap:4px;min-width:0}.meta-row__separator{color:var(--text-tertiary)}.card-type-meta{display:inline-flex;align-items:center;gap:4px;color:var(--text-secondary);font-size:.8rem;font-weight:600}.save-action-button{width:44px;height:44px;border-radius:var(--radius-icon-button);border:1px solid rgba(70,51,33,.1);background:#fffbf7f5;color:var(--text-secondary);box-shadow:none;display:inline-flex;align-items:center;justify-content:center}.save-action-button.is-saved{color:var(--brand-primary);background:#d9ede8f5}.responsive-media,.card-image-fallback{width:100%;height:100%;border-radius:inherit;overflow:hidden}.media-thumb{display:block;overflow:hidden;border-radius:var(--media-thumb-radius, inherit)}.responsive-media img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.compact-media-card__thumb.responsive-media,.compact-media-card__thumb.card-image-fallback,.notice-card--with-media .notice-card__thumb.responsive-media,.notice-card--with-media .notice-card__thumb.card-image-fallback{width:var(--compact-thumb-width);height:var(--compact-thumb-height)}.card-image-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:linear-gradient(180deg,#d9ede866,#efe5d9b8),var(--bg-soft);color:var(--brand-primary)}.card-image-fallback--compact{gap:6px}.card-image-fallback__icon{display:inline-flex;align-items:center;justify-content:center}.card-image-fallback__label{font-size:.76rem;font-weight:700;color:var(--text-secondary)}.card-time-meta{margin-top:auto}.notice-card__tap{width:100%;padding:var(--card-padding-regular);text-align:left;border-radius:inherit;transition:transform .14s ease}.notice-card__tap:hover,.notice-card__tap:active{transform:translateY(-1px)}.notice-card__title{margin:0;font-size:1rem;font-weight:700;line-height:1.34;color:var(--text-primary);overflow-wrap:anywhere;word-break:keep-all}.notice-card__layout{display:block}.notice-card__stack{display:flex;flex-direction:column;gap:var(--card-row-gap)}.notice-card .card-bottom-meta-row .meta-row__item:last-child{color:var(--text-tertiary);font-weight:500;font-size:.78rem}.notice-card--with-media .notice-card__copy{padding-right:2px}.notice-card--institution .notice-card__copy p{-webkit-line-clamp:3}.notice-card__copy p{color:var(--text-secondary);font-size:.9rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notice-card--no-media .notice-card__thumb{display:none}.notice-card__footer{padding:0 14px 14px}.notice-card__actions{display:flex;gap:8px;flex-wrap:wrap}.notice-card.is-unread{outline:2px solid rgba(196,99,43,.12)}.weather-card{padding:18px;background:linear-gradient(180deg,#2b68ad1a,#e8f0fbf0),var(--bg-surface);border-color:#2b68ad24}.weather-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.weather-card__header strong{display:block;margin-top:6px;font-size:1.08rem}.weather-card__switcher,.segmented-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.weather-card__switcher::-webkit-scrollbar,.segmented-row::-webkit-scrollbar,.chip-grid::-webkit-scrollbar{display:none}.weather-card__switch,.segmented-row__button,.choice-chip{min-height:44px;padding:0 14px;border-radius:var(--radius-pill);border:1px solid var(--line-soft);background:#fffbf7c7;color:var(--text-secondary);font-weight:700;white-space:nowrap}.weather-card__switch.is-active,.segmented-row__button.is-active,.choice-chip.is-selected{border-color:#165c522e;background:var(--brand-primary-soft);color:var(--brand-primary)}.weather-card__body{width:100%;text-align:left;display:flex;align-items:flex-end;justify-content:space-between;gap:18px}.weather-card__temp{font-size:2.6rem;line-height:1;font-family:Plus Jakarta Sans,sans-serif}.weather-card__body p,.status-line,.collection-card__main span,.content-card__meta span,.content-card__source,.empty-state-card p,.keyword-card p,.keyword-card span,.choice-row__copy span,.rank-card__copy span,.weather-detail__summary,.detail-summary p,.detail-reminder-banner span,.bottom-sheet__title-wrap span{color:var(--text-secondary);line-height:1.45}.weather-card__meta{display:flex;flex-direction:column;gap:6px;align-items:flex-end;font-size:.88rem}.summary-grid,.collection-grid,.region-card-grid,.hourly-grid{display:grid;gap:12px}.summary-grid,.collection-grid{grid-template-columns:1fr}.region-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hourly-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.input-shell{display:block}.input-shell--grow{flex:1}.search-bar,.inline-field,.sheet-footer-inline,.bottom-sheet__header,.bottom-sheet__header-actions,.detail-meta-row,.detail-tags,.detail-reminder-banner,.content-card__topline,.content-card__chips,.content-card__meta,.reminder-row__meta,.keyword-card,.keyword-card__main,.reminder-alert-card__meta,.region-card,.rank-card,.choice-row,.choice-row--form,.collection-card--row,.collection-card__cover{display:flex;gap:10px}.search-bar,.inline-field,.sheet-footer-inline{align-items:center}.filter-group{display:flex;flex-direction:column;gap:10px;padding-top:12px}.filter-group__label{font-size:.82rem;font-weight:700;color:var(--text-secondary)}.chip-grid{display:flex;gap:8px;flex-wrap:wrap;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.meta-chip{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:var(--radius-chip);background:var(--bg-soft);color:var(--text-secondary);font-size:.74rem;font-weight:700}.meta-chip--region{background:var(--brand-primary-soft);color:var(--brand-primary)}.meta-chip--accent{background:var(--brand-accent-soft);color:var(--brand-accent)}.meta-chip--ghost{background:#65584c14}.weather-forecast-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;margin-top:10px;padding:10px 0;border:1px solid rgba(43,104,173,.12);border-radius:var(--weather-plane-radius);background:#ffffff57}.weather-forecast-strip__item{min-width:0;padding:0 10px;display:flex;flex-direction:column;gap:4px}.weather-forecast-strip__item+.weather-forecast-strip__item{border-left:1px solid rgba(43,104,173,.1)}.weather-forecast-strip__label,.weather-forecast-strip__note{font-size:.71rem;line-height:1.25}.weather-forecast-strip__label{color:var(--text-secondary);font-weight:700}.weather-forecast-strip__main{display:flex;align-items:center;gap:6px}.weather-forecast-strip__icon{color:var(--info-blue);display:inline-flex;align-items:center}.weather-forecast-strip__main strong{font-size:.9rem;line-height:1}.weather-forecast-strip__note{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.content-card,.reminder-row,.reminder-alert-card,.keyword-card{position:relative}.content-card__tap{width:100%;text-align:left;padding:15px}.content-card__save{position:absolute;top:12px;right:12px;width:44px;height:44px;border-radius:50%;border:1px solid var(--line-soft);background:#fffbf7f0;box-shadow:var(--shadow-soft);display:inline-flex;align-items:center;justify-content:center}.content-card.is-unread{outline:2px solid rgba(196,99,43,.12)}.content-card__topline{align-items:flex-start;justify-content:space-between;margin-bottom:12px;padding-right:52px}.content-card__chips{flex-wrap:wrap}.content-card__source{font-size:.82rem;white-space:nowrap}.content-card__body,.content-card__body.has-image{align-items:stretch}.content-card__text{flex:1;min-width:0}.content-card__text h3{font-size:1rem;line-height:1.35;margin-bottom:8px}.content-card__text p{color:var(--text-secondary);line-height:1.5;font-size:.92rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.content-card__meta{flex-wrap:wrap;margin-top:12px;font-size:.84rem}.content-card__time-flag{display:inline-flex;align-items:center;gap:4px}.content-card__image-wrap{width:88px;min-width:88px;height:88px;border-radius:16px;overflow:hidden}.content-card__image-wrap img,.detail-hero img,.collection-card__thumb img{width:100%;height:100%;object-fit:cover}.content-card--dense .content-card__tap{padding:13px}.content-card--dense .content-card__text h3{font-size:.96rem}.empty-state-card{padding:20px 18px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}.empty-state-card__icon{width:52px;height:52px;border-radius:18px;background:var(--bg-soft);display:inline-flex;align-items:center;justify-content:center;color:var(--brand-primary)}.empty-state-card strong{font-size:1.08rem}.empty-state-card__actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.empty-state-card--hero{max-width:720px;align-items:flex-start;text-align:left;gap:12px}.empty-state-card--hero .empty-state-card__actions{justify-content:flex-start}.region-group{display:flex;flex-direction:column;gap:10px}.collection-card--row{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;text-align:left}.collection-card__lead{flex-shrink:0}.collection-card__cover{min-width:0;align-items:stretch}.collection-card__cover--inline{display:flex;gap:4px;align-items:center}.collection-card__thumb,.collection-card__placeholder{width:44px;height:44px;border-radius:14px;overflow:hidden;background:var(--bg-soft);display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:.74rem;font-weight:700}.collection-card__placeholder{background:#165c5214;color:var(--brand-primary)}.collection-card__main{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px;align-items:flex-start;border:none;background:transparent;padding:0;cursor:pointer;font:inherit;text-align:left}.collection-card__main strong{font-size:.98rem;color:var(--text-primary)}.collection-card__main span{color:var(--text-secondary);font-size:.82rem;line-height:1.35}.collection-card__menu{flex-shrink:0}.saved-collections-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.saved-collections-toolbar .section-header{margin-bottom:0}.saved-collections-toolbar__new{flex-shrink:0;font-size:.86rem}.saved-collections-section{gap:16px}.saved-collections-intro{padding:14px 16px;border-radius:var(--radius-card-regular);border:1px solid rgba(22,92,82,.14);background:#165c520d;display:flex;flex-direction:column;gap:8px}.saved-collections-intro__icon{color:var(--brand-primary);display:inline-flex}.saved-collections-intro__title{margin:0;font-size:.95rem;font-weight:700;color:var(--text-primary)}.saved-collections-intro__body{margin:0;font-size:.86rem;color:var(--text-secondary);line-height:1.45}.saved-collections-intro__actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.saved-collections-intro__limit{margin:0;font-size:.78rem;color:var(--text-tertiary);line-height:1.4}.saved-data-footer{margin-top:8px;padding:14px 16px;border-radius:var(--radius-card-regular);border:1px solid var(--line-soft);background:#fffbf7a6;display:flex;flex-direction:column;gap:12px}.saved-data-footer__lead{margin:0;font-size:.82rem;color:var(--text-secondary);line-height:1.45}.saved-data-footer__actions{display:flex;flex-direction:column;gap:8px}.saved-data-footer__btn{justify-content:center;gap:8px;font-size:.88rem}.saved-data-footer__hint{margin:0;font-size:.78rem;color:var(--text-tertiary);line-height:1.4}.saved-feed-item{display:flex;align-items:stretch;gap:8px}.saved-feed-item__body{flex:1;min-width:0}.saved-feed-item__move{flex-shrink:0;align-self:flex-start;margin-top:4px}.collection-actions-list{display:flex;flex-direction:column;gap:0;border-radius:var(--radius-card-regular);border:1px solid var(--line-soft);overflow:hidden}.collection-actions-list__item{width:100%;padding:14px 16px;border:none;border-bottom:1px solid rgba(70,51,33,.08);background:#fffbf780;font-size:.92rem;font-weight:600;text-align:left;cursor:pointer;color:var(--text-primary)}.collection-actions-list__item:last-child{border-bottom:none}.collection-actions-list__item--danger{color:var(--danger)}.sheet-hint{margin:0 0 12px;font-size:.86rem;color:var(--text-secondary);line-height:1.45}.inline-helper--warn,.inline-helper--limit{color:var(--text-secondary);font-size:.82rem}.inline-helper--limit{padding:10px 12px;border-radius:var(--radius-card-regular);background:#ae432c0f;border:1px solid rgba(174,67,44,.12)}.inline-helper--muted{margin:8px 0 0;font-size:.78rem;color:var(--text-tertiary)}.choice-row--warn{border-color:#ae432c33}.saved-delete-confirm{width:100%;justify-content:center}.keyword-chip-toggle{display:inline-flex;align-items:center;gap:6px}.keyword-chip-toggle__label{min-width:0}.keyword-chip-toggle__check{flex-shrink:0;color:var(--brand-primary)}.removable-keyword-chip{display:inline-flex;align-items:center;gap:10px;max-width:100%}.removable-keyword-chip .removable-keyword-chip__toggle{flex:1;min-width:0}.removable-keyword-chip .removable-keyword-chip__remove{flex-shrink:0}.keyword-chip-grid--removable{gap:10px 12px}.keyword-rule-block{display:flex;flex-direction:column;gap:8px}.keyword-rule-block--compact{gap:10px}.keyword-rule-empty{margin:0;padding:4px 2px 8px;font-size:.84rem;line-height:1.45;color:var(--text-secondary)}.keyword-add-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--line-soft);display:flex;flex-direction:column;gap:12px}.keyword-add-section__fields{display:flex;flex-direction:column;gap:12px}.keyword-add-section__submit{width:100%;justify-content:center}.choice-chip{gap:8px}.choice-row,.rank-card,.region-card,.hourly-grid__item{border-radius:20px;border:1px solid var(--line-soft);background:var(--bg-soft);padding:14px}.choice-row,.rank-card,.region-card{align-items:center;justify-content:space-between;width:100%;text-align:left}.choice-row.is-selected,.region-card.is-selected{background:var(--brand-primary-soft);border:1px solid rgba(22,92,82,.16)}.choice-row.is-muted{opacity:.72}.choice-row--form{align-items:stretch;flex-direction:column}.choice-row__copy,.rank-card__copy{display:flex;flex-direction:column;gap:4px}.region-card__order{width:30px;height:30px;border-radius:50%;background:var(--brand-primary);color:#f6fffc;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.rank-card__actions,.reminder-row__actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.bottom-tab-bar{position:fixed;inset:auto 0 0;left:0;right:0;--tabbar-gutter: clamp(16px, 3.8vw, 32px);width:min(calc(100% - (var(--tabbar-gutter) * 2)),var(--tabbar-max));margin:0 auto;box-sizing:border-box;padding-block:7px;padding-inline:max(8px,env(safe-area-inset-left,0px)) max(8px,env(safe-area-inset-right,0px));border-radius:22px;border:1px solid var(--line-soft);background:#fffbf7eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-soft);z-index:20;bottom:calc(12px + var(--bottom-safe));display:grid;grid-template-columns:repeat(4,minmax(0,1fr));column-gap:6px;align-items:stretch}@supports (width: 1svw){.bottom-tab-bar{--tabbar-gutter: clamp(16px, 3.8svw, 32px);width:min(calc(100svw - (var(--tabbar-gutter) * 2)),var(--tabbar-max))}}.bottom-tab-bar__button{position:relative;z-index:0;width:100%;min-width:0;min-height:52px;height:52px;margin:0;padding:0;border:none;border-radius:0;background:transparent;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:color .14s ease,transform .1s ease;-webkit-tap-highlight-color:transparent}.bottom-tab-bar__button:active{transform:scale(.98)}.bottom-tab-bar__button:focus-visible{outline:2px solid rgba(22,92,82,.45);outline-offset:2px;z-index:2}.bottom-tab-bar__content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:100%;padding:0;gap:3px;pointer-events:none}.bottom-tab-bar__icon{display:flex;align-items:center;justify-content:center;width:24px;height:22px;flex-shrink:0}.bottom-tab-bar__icon svg{display:block;width:20px;height:20px}.bottom-tab-bar__label{display:block;max-width:100%;margin:0;padding:0 1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.72rem;line-height:1.2;font-weight:700;letter-spacing:-.02em;text-align:center}.bottom-tab-bar__button.is-active{color:var(--brand-primary)}.bottom-tab-bar__button.is-active:before{content:"";position:absolute;top:5px;right:3px;bottom:5px;left:3px;border-radius:11px;background:var(--brand-primary-soft);box-shadow:inset 0 0 0 1px #165c5214;z-index:0;pointer-events:none}@media (prefers-reduced-motion: reduce){.bottom-tab-bar__button{transition:none}.bottom-tab-bar__button:active{transform:none}}.bottom-sheet{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;justify-content:center;opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:50}.bottom-sheet.is-open{opacity:1;pointer-events:auto}.bottom-sheet__scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:#16110c57}.bottom-sheet__panel{position:absolute;inset:auto 0 0;width:100%;max-width:var(--sheet-max);max-height:min(75dvh,820px);background:var(--bg-base);border-radius:30px 30px 0 0;padding:18px 18px calc(20px + var(--bottom-safe));transform:translateY(100%);transition:transform .22s ease;display:flex;flex-direction:column;overflow:hidden;z-index:1}.bottom-sheet.is-open .bottom-sheet__panel{transform:translateY(0)}.content-detail-sheet.bottom-sheet__panel,.collection-picker-sheet.bottom-sheet__panel{max-height:min(75dvh,820px)}.content-detail-sheet{padding-bottom:calc(12px + var(--bottom-safe))}.bottom-sheet__title-wrap{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.bottom-sheet__header{align-items:flex-start;justify-content:space-between;flex-shrink:0}.bottom-sheet__header--minimal{justify-content:flex-end;min-height:44px}.bottom-sheet__title-wrap strong{font-size:1.08rem}.bottom-sheet__body{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:16px;padding-top:12px}.bottom-sheet__footer{position:sticky;bottom:calc(-18px - var(--bottom-safe));margin-inline:-18px;padding:16px 18px calc(8px + var(--bottom-safe));background:linear-gradient(180deg,rgba(245,239,231,0),var(--bg-base) 32%);flex-shrink:0;padding-top:16px}.icon-button{width:44px;height:44px;border-radius:50%;border:1px solid var(--line-soft);background:var(--bg-soft);display:inline-flex;align-items:center;justify-content:center}.detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.detail-header__copy{display:flex;flex-direction:column;gap:6px}.detail-header__copy h2{font-size:1.36rem;line-height:1.2}.detail-meta-row,.detail-tags,.detail-reminder-banner{flex-wrap:wrap}.detail-hero{width:100%;aspect-ratio:1.18;border-radius:24px;overflow:hidden;background:var(--surface-muted)}.detail-summary,.expandable-body,.weather-detail{display:flex;flex-direction:column;gap:10px}.detail-summary strong{font-size:.92rem}.expandable-body__content{display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}.expandable-body__content.is-open{display:block}.expandable-body__content p{margin-bottom:12px;color:var(--text-secondary);line-height:1.6}.expandable-body__toggle{min-height:44px;align-self:flex-start;color:var(--brand-primary);font-weight:700}.detail-reminder-banner{align-items:center}.detail-action-bar{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding-bottom:max(0px,var(--bottom-safe))}.detail-action-bar__button{min-height:64px;padding:10px 8px;border-radius:20px;border:1px solid var(--line-soft);background:#fffbf7eb;color:var(--text-primary);display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-size:.78rem;font-weight:700;text-align:center}.detail-action-bar__button.is-danger{background:#ae432c1a;color:var(--danger);border-color:#ae432c38}.detail-action-bar--flex{display:flex;flex-wrap:wrap;gap:10px}.detail-action-bar--flex .detail-action-bar__button{flex:1 1 calc(33.333% - 7px);min-width:76px}.detail-title-block{margin:0;font-size:1.36rem;line-height:1.22;font-family:Plus Jakarta Sans,sans-serif;letter-spacing:-.03em}.detail-meta-line{margin:0;font-size:.86rem;line-height:1.45;color:var(--text-secondary)}.detail-summary-text{margin:0;font-size:.95rem;line-height:1.6;color:var(--text-primary)}.detail-context-note{margin:0;font-size:.82rem;line-height:1.45;color:var(--text-secondary)}.full-content-body{display:flex;flex-direction:column;gap:12px;padding-bottom:8px}.full-content-body p{margin:0;color:var(--text-secondary);line-height:1.65;font-size:.94rem}.content-detail-sheet__body-inner{padding-bottom:8px}.content-detail-sheet .full-content-body{padding-bottom:22px}.detail-flow-step__title,.detail-reminder-offer__title{margin:0 0 4px;font-size:1.02rem;font-weight:700;font-family:Plus Jakarta Sans,sans-serif}.detail-reminder-offer__sub{margin:0 0 16px;font-size:.9rem;color:var(--text-secondary)}.detail-reminder-offer__actions{display:flex;flex-direction:column;gap:10px}.detail-reminder-offer__actions .primary-button,.detail-reminder-offer__actions .secondary-button{width:100%;justify-content:center}.detail-step-footer{display:flex;gap:10px;width:100%}.detail-step-footer .secondary-button,.detail-step-footer .primary-button,.detail-step-footer--balanced .detail-step-footer__btn{flex:1;justify-content:center}.save-flow-sheet{display:flex;flex-direction:column;gap:28px}.save-flow-sheet .stack-list+.section-header{margin-top:8px;padding-top:24px}.collection-picker-sheet .bottom-sheet__body{gap:22px}.save-flow-sheet .choice-row{background:#fffbf7a6;border-color:#46332117;box-shadow:none}.save-flow-sheet .choice-row.is-selected{background:#d9ede88c;border-color:#165c5233}.save-flow-sheet .choice-row--form{gap:10px}.save-flow-sheet .reminder-preset-form .choice-row{background:#fffbf7a6}.save-sheet-footer{display:flex;gap:10px;width:100%}.save-sheet-footer .secondary-button{flex:1;justify-content:center}.save-reminder-section{border-radius:18px;border:1px solid rgba(70,51,33,.1);background:#fffdfae0;overflow:hidden;box-shadow:none}.save-reminder-section__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border:none;background:transparent;text-align:left;cursor:pointer;font:inherit;color:inherit}.save-reminder-section__toggle-text{display:flex;flex-direction:column;gap:4px;min-width:0}.save-reminder-section__toggle-title{font-weight:700;font-size:.95rem}.save-reminder-section__optional{font-weight:600;color:var(--text-tertiary);font-size:.86rem}.save-reminder-section__hint{font-size:.82rem;color:var(--text-secondary);line-height:1.4}.save-reminder-section__chev{flex-shrink:0;color:var(--text-tertiary);transition:transform .18s ease}.save-reminder-section__toggle.is-open .save-reminder-section__chev{transform:rotate(180deg)}.save-reminder-section__panel{padding:4px 12px 14px;border-top:1px solid rgba(70,51,33,.07)}.save-reminder-section .reminder-preset-form{gap:10px}.reminder-picker-inline .sheet-link-button{width:100%;margin-top:4px}.keyword-card,.reminder-row{padding:14px;align-items:center;justify-content:space-between}.keyword-card__main,.reminder-row__main{flex:1;text-align:left;align-items:center;justify-content:space-between}.keyword-card__main strong,.reminder-row__copy strong,.reminder-alert-card strong,.hourly-grid__item strong{font-size:.96rem}.reminder-alert-card{width:100%;padding:16px;text-align:left}.toast{position:fixed;left:50%;transform:translate(-50%);bottom:calc(92px + var(--bottom-safe));width:min(calc(100vw - 24px),420px);padding:12px 14px;border-radius:20px;background:#221a14f0;color:#fff7f0;display:flex;align-items:center;gap:10px;z-index:70;box-shadow:0 18px 40px #00000038}.toast.is-warning{background:#7a341df5}.toast__icon{width:34px;height:34px;border-radius:12px;background:#ffffff1f;display:inline-flex;align-items:center;justify-content:center}.toast__message{flex:1;font-size:.9rem}@media (min-width: 720px){.summary-grid,.collection-grid,.feature-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.region-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.tab-toolbar{padding-inline:16px}}@media (min-width: 980px){.summary-grid,.feature-card-grid,.collection-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 640px){:root{--compact-thumb-width: 118px;--compact-thumb-height: 92px}.tab-toolbar{flex-direction:column;align-items:stretch}.tab-toolbar__action{width:100%}.home-page-header{align-items:flex-start}.home-page-header__copy h1{font-size:1.72rem}.home-page-header__action{padding-inline:13px}.status-inline-panel{gap:10px}.status-inline-panel .secondary-button{align-self:center;padding-inline:14px}.weather-summary-card__main{display:block}.weather-summary-card__stats{gap:8px;margin-top:6px}.weather-summary-card__headline{align-items:center;gap:10px}.compact-media-card__tap,.notice-card__tap{padding:13px}}@media (max-width: 380px){.weather-forecast-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.weather-forecast-strip__item{padding:8px 10px}.weather-forecast-strip__item+.weather-forecast-strip__item{border-left:0}.weather-forecast-strip__item:nth-child(2n){border-left:1px solid rgba(43,104,173,.1)}.weather-forecast-strip__item:nth-child(n+3){border-top:1px solid rgba(43,104,173,.1)}.home-page-header{gap:12px}.home-page-header__action{min-width:124px}.status-inline-panel__copy p{font-size:.8rem}.weather-summary-card__headline{gap:8px}.weather-summary-card__headline p{font-size:.86rem}.weather-summary-card__stats{gap:6px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
