:root{color-scheme:light;--color-bg-start:#faf8f4;--color-bg-end:#f3eef0;--color-surface:#fff;--color-surface-alt:#fffdf9;--color-primary:#7a5040;--color-primary-hover:#6a4030;--color-brand:#8c5a36;--color-accent:#c49a7a;--color-accent-light:#f5e8dc;--color-accent-surface:#faf2eb;--color-accent-text:#6b4226;--color-warm:#b85a2c;--color-warm-light:#fff0e8;--color-text-primary:#2d2b3a;--color-text-secondary:#4a4860;--color-text-muted:#6b6880;--color-border:#ece8ee;--color-border-accent:#e0cfc0;--color-danger:#b3261e;--color-success:#2e7d32;--text-xs:14px;--text-sm:15px;--text-base:17px;--text-md:18px;--text-lg:20px;--text-xl:24px;--text-2xl:28px;--text-3xl:32px;--line-base:1.65;--radius-sm:12px;--radius-md:16px;--radius-lg:20px;--radius-xl:24px}*{box-sizing:border-box}[role=button],button{min-height:44px;font-size:inherit}.skip-link{position:absolute;top:-48px;left:8px;z-index:9999;padding:8px 16px;min-height:44px;display:flex;align-items:center;background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);font-weight:700;font-size:var(--text-sm);text-decoration:none;transition:top .15s}.skip-link:focus{top:8px}html{background:var(--color-bg-end)}body{margin:0;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Noto Sans KR,sans-serif;font-size:var(--text-base);line-height:var(--line-base);background:linear-gradient(160deg,var(--color-bg-start) 0,var(--color-bg-end) 100%);color:var(--color-text-primary);-webkit-font-smoothing:antialiased}a{color:inherit}.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-root{min-height:100vh;display:flex;justify-content:center;padding:24px 16px}.app-shell{width:100%;max-width:480px}.app-shell-with-tab-bar{padding-bottom:calc(80px + env(safe-area-inset-bottom, 0px))}.app-footer{margin-top:24px;padding:16px;text-align:center}.app-footer-brand,.app-footer-links{display:none}.app-footer-meta{display:flex;flex-direction:column;gap:4px;color:var(--color-text-muted);font-size:13px;line-height:1.5}.app-footer-meta a{color:inherit}.centered-stack{background:var(--color-surface);border:1px solid var(--color-border);border-radius:18px;box-shadow:0 8px 32px rgba(160,82,45,.08);padding:24px 20px;min-height:calc(100vh - 48px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center}.align-left{text-align:left;align-items:stretch;justify-content:flex-start}.login-stack{padding-top:15vh}.brand-badge{margin:0;color:var(--color-brand);font-weight:700;font-size:var(--text-sm)}.page-title{margin:0;font-family:inherit;font-size:var(--text-3xl);line-height:1.3;color:var(--color-text-primary);letter-spacing:-.02em;font-weight:800}.page-description{margin:0;color:var(--color-text-secondary);font-size:var(--text-base);line-height:var(--line-base)}.date-text{margin-top:6px;margin-bottom:20px;color:var(--color-text-muted);font-size:var(--text-sm)}.feature-card{border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:22px;background:var(--color-surface);margin-bottom:14px;box-shadow:0 4px 16px rgba(45,43,58,.04);transition:box-shadow .2s ease,transform .2s ease}.feature-card:hover{box-shadow:0 8px 24px rgba(45,43,58,.08);transform:translateY(-1px)}.feature-card.muted{border-color:var(--color-border);background:var(--color-surface-alt)}.card-title{margin:0 0 10px;font-size:var(--text-lg);font-weight:700;color:var(--color-text-primary)}.card-description{margin:0 0 14px;color:var(--color-text-secondary);font-size:var(--text-base);line-height:var(--line-base)}.kakao-button,.primary-button,.secondary-button{width:100%;min-height:60px;border-radius:var(--radius-md);border:0;font-size:var(--text-md);font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s ease}.kakao-button{background:#fee500;color:#1f2937;margin-top:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.kakao-button:disabled{opacity:.7;cursor:not-allowed}.primary-button{background:var(--color-primary);color:#fff;box-shadow:0 4px 14px rgba(139,111,94,.25)}.primary-button:hover{background:var(--color-primary-hover)}.primary-button:active{transform:scale(.98)}.secondary-button{background:var(--color-surface);color:var(--color-text-primary);border:1.5px solid var(--color-border)}.secondary-button:hover{background:var(--color-surface-alt)}.text-button{width:100%;margin-top:4px;border:0;background:transparent;color:var(--color-primary);min-height:48px;font-size:var(--text-sm);cursor:pointer;font-family:inherit}.error-text{margin:2px 0 0;color:var(--color-danger);font-size:15px;line-height:1.4}.spinner{width:28px;height:28px;border-radius:9999px;border:3px solid var(--color-border);animation:spin .9s linear infinite}.form-stack{display:flex;flex-direction:column;gap:10px;margin-top:8px}.field-label{margin:0;font-size:15px;font-weight:600}.text-input{width:100%;min-height:48px;border-radius:10px;border:1px solid var(--color-border);padding:0 12px;font-size:16px}.radio-row{display:flex;align-items:center;gap:12px;min-height:52px;padding:4px 0}.link-button{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.facilities-layout{background:var(--color-surface);border:1px solid var(--color-border);border-radius:18px;box-shadow:0 8px 32px rgba(160,82,45,.08);padding:20px;min-height:calc(100vh - 48px);display:flex;flex-direction:column;gap:14px}.facilities-header .page-title{font-size:28px}.facilities-toolbar{display:flex;flex-direction:column;gap:8px}.toolbar-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;grid-gap:8px;gap:8px}.radius-input{min-height:44px}.active-filter-row{display:flex;flex-wrap:wrap;gap:6px}.filter-chip{display:inline-flex;align-items:center;min-height:30px;padding:0 10px;border-radius:999px;border:1px solid var(--color-border);background:#fffaf3;color:var(--color-text-secondary);font-size:13px}.offline-banner{margin:0;border-radius:10px;border:1px solid #f2be90;background:#fff0e0;color:#934b06;padding:10px 12px;font-size:14px}.map-panel{border:1px solid var(--color-border);border-radius:12px;background:radial-gradient(circle at 20% 20%,#fff6ea,#f2e1cb 70%);padding:8px}.map-grid{position:relative;width:100%;height:220px;border-radius:10px;border:1px dashed rgba(160,82,45,.4);overflow:hidden}.map-empty{margin:0;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:14px}.map-pin{position:absolute;width:14px;height:14px;border-radius:9999px;border:2px solid #fff;background:var(--color-primary);transform:translate(-50%,-50%);cursor:pointer}.map-pin.active{background:#0f766e}.facility-list{display:flex;flex-direction:column;gap:8px}.facility-card{border:1px solid var(--color-border);border-radius:12px;padding:12px;background:#fff}.facility-card p{margin:4px 0;font-size:14px;color:var(--color-text-secondary)}.facility-card h2{margin:0;font-size:17px}.facility-card-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.favorite{min-width:40px;min-height:36px;border-radius:10px;border:1px solid var(--color-border);background:#fff;cursor:pointer;font-size:18px}.favorite.on{border-color:#e39b16;background:#fff8df;color:#a16207}.detail-panel{border:1px solid var(--color-border-accent);background:#fff8f1;border-radius:12px;padding:12px}.filter-sheet-backdrop{position:fixed;inset:0;background:rgba(45,31,20,.4);display:flex;justify-content:center;align-items:flex-end;z-index:30}.filter-sheet{width:min(480px,100%);background:var(--color-surface);border-radius:16px 16px 0 0;border:1px solid var(--color-border);padding:16px;display:flex;flex-direction:column;gap:12px;max-height:80vh;overflow-y:auto}.filter-sheet h2{margin:0;font-size:22px}.sheet-block{display:flex;flex-direction:column;gap:8px}.sheet-label{margin:0;font-size:14px;color:var(--color-text-secondary)}.sheet-options{display:flex;flex-wrap:wrap;gap:8px}.sheet-chip{min-height:36px;padding:0 12px;border-radius:999px;border:1px solid var(--color-border);background:#fff;color:var(--color-text-secondary);cursor:pointer}.sheet-chip.selected{border-color:var(--color-border-accent);background:#ffe8d4;color:var(--color-primary-hover)}.sheet-actions{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}@media (max-width:420px){.toolbar-row{grid-template-columns:1fr 1fr}}.detail-panel p{margin:4px 0;font-size:14px}.detail-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.detail-header h2{margin:0;font-size:18px}.detail-note{color:var(--color-text-muted)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in-up{animation:fadeInUp .45s ease-out}.address-link,.phone-link{display:block;margin:4px 0;font-size:14px;color:var(--color-primary);text-decoration:none}.address-link:hover,.phone-link:hover{text-decoration:underline}.detail-address-row{gap:4px;margin:4px 0;font-size:14px}.detail-address-links,.detail-address-row{display:flex;flex-wrap:wrap;align-items:baseline}.detail-address-links{gap:8px}.map-link-button{display:inline-block;padding:2px 8px;border-radius:6px;font-size:12px;background:var(--color-primary);color:#fff;text-decoration:none;white-space:nowrap}.map-link-button:hover{opacity:.85}.eval-section{margin:12px 0;padding:12px;background:#fef9f4;border:1px solid var(--color-border-accent);border-radius:8px}.eval-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.eval-stars{display:inline-flex;gap:2px;font-size:20px;line-height:1}.star.filled{color:#f0a500}.star.empty{color:#d4c8be}.eval-grade-badge{display:inline-block;padding:2px 8px;border-radius:4px;background:var(--color-primary);color:#fff;font-size:13px;font-weight:600}.eval-score{font-size:13px;color:var(--color-text-secondary)}.eval-source-badge{padding:2px 8px;border-radius:4px;background:#e8f5e9;color:#2e7d32;font-weight:600;letter-spacing:.02em}.eval-source-badge,.eval-year{display:inline-block;margin-top:6px;font-size:11px}.eval-year{margin-left:6px;color:var(--color-text-muted)}.eval-breakdown{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.eval-item{display:inline-block;padding:2px 8px;border-radius:4px;background:var(--color-surface);border:1px solid var(--color-border);font-size:11px;color:var(--color-text-secondary)}.empty-state-card{border:2px dashed var(--color-border-accent);border-radius:16px;padding:24px 16px;background:linear-gradient(135deg,#fffaf3,#fff5eb);margin-bottom:14px;text-align:center}.empty-state-icon{font-size:48px;margin-bottom:12px}.empty-state-title{font-family:"Noto Serif KR",Georgia,serif;font-size:22px;line-height:1.4;color:var(--color-brand);margin:0 0 8px;white-space:pre-line}.empty-state-description{font-size:15px;line-height:1.6;margin:0 0 16px}.cf-layout{position:relative;min-height:calc(100vh - 48px);background:var(--color-bg-start);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 12px 40px rgba(45,43,58,.06)}.cf-header{position:relative;background:linear-gradient(135deg,var(--color-accent) 0,#d4a882 50%,#e8cdb8 100%);padding:36px 24px 60px;color:var(--color-text-primary);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.cf-header-content{position:relative;z-index:1}.cf-brand{font-size:var(--text-sm);font-weight:700;letter-spacing:.04em;color:var(--color-text-secondary);display:block;margin-bottom:10px}.cf-title{margin:0 0 14px;font-size:var(--text-3xl);line-height:1.3;font-family:inherit;font-weight:800}.cf-desc{margin:0;font-size:var(--text-base);color:var(--color-text-secondary);line-height:var(--line-base)}.cf-search-card{position:relative;z-index:10;margin:-40px 20px 0;background:var(--color-surface);border-radius:var(--radius-xl);padding:18px;box-shadow:0 8px 24px rgba(45,43,58,.08);display:flex;flex-direction:column;gap:14px;font-family:inherit}.cf-search-input-wrap{display:flex;align-items:center;background:var(--color-bg-start);border-radius:var(--radius-md);padding:0 14px;border:1px solid var(--color-border)}.cf-search-icon{font-size:18px;opacity:.6}.cf-search-input{flex:1 1;background:transparent;border:none;min-height:52px;padding:0 12px;font-size:var(--text-base);outline:none;color:var(--color-text-primary);font-family:inherit}.cf-radius-slider-wrap{background:var(--color-accent-surface);border-radius:var(--radius-md);padding:14px;border:1px solid var(--color-accent-light)}.cf-slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary)}.cf-slider-val{color:var(--color-accent-text);font-weight:700;font-size:var(--text-base)}.cf-slider{width:100%;accent-color:var(--color-accent)}.cf-search-actions{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.cf-action-btn{background:var(--color-bg-start);border:1px solid var(--color-border);border-radius:var(--radius-md);min-height:50px;font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all .15s;font-family:inherit}.cf-action-btn:hover{background:var(--color-surface)}.cf-action-btn:active{transform:scale(.98)}.cf-filter-btn{border-radius:999px}.cf-active-filters{display:flex;flex-wrap:wrap;gap:6px;padding-top:4px}.cf-chip{background:var(--color-accent-surface);color:var(--color-accent-text);font-size:var(--text-sm);font-weight:600;padding:6px 12px;border-radius:999px}.cf-main-content{padding:20px;display:flex;flex-direction:column;gap:24px}.cf-error-banner,.cf-offline-banner{background:#fff0eb;border:1px solid #ffd4c4;color:#b3261e;padding:14px;border-radius:var(--radius-md);font-size:var(--text-sm);text-align:center}.cf-info-banner{background:var(--color-accent-surface);border:1px solid var(--color-accent-light);color:var(--color-accent-text);padding:12px 16px;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;text-align:center}.cf-map-section{display:flex;flex-direction:column;gap:12px}.cf-map-header{display:flex;justify-content:space-between;align-items:center}.cf-map-header h3{margin:0;font-size:var(--text-lg);font-weight:700;color:var(--color-text-primary)}.cf-map-header span{font-size:var(--text-sm);color:var(--color-text-muted);background:var(--color-bg-end);padding:4px 10px;border-radius:999px;font-weight:600}.cf-map-grid{position:relative;width:100%;height:200px;background:var(--color-bg-end);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);box-shadow:inset 0 2px 8px rgba(0,0,0,.03)}.cf-map-empty{display:flex;align-items:center;justify-content:center;height:100%;font-size:14px;color:#888}.cf-map-pin{position:absolute;width:16px;height:16px;background:#ff5722;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);cursor:pointer;box-shadow:0 2px 6px rgba(255,87,34,.4);transition:transform .2s,background .2s}.cf-map-pin:hover{transform:translate(-50%,-50%) scale(1.3);z-index:2}.cf-map-pin.active{background:#1976d2;box-shadow:0 0 0 4px rgba(25,118,210,.2);z-index:3}.cf-cards{display:flex;flex-direction:column;gap:16px}.cf-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:22px;box-shadow:0 4px 14px rgba(45,43,58,.04);transition:transform .15s ease,box-shadow .15s ease;font-family:inherit}.cf-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(45,43,58,.08)}.cf-card-tags{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.cf-tag-type{background:var(--color-accent-surface);color:var(--color-accent-text)}.cf-tag-dist,.cf-tag-type{font-size:var(--text-sm);font-weight:600;padding:5px 10px;border-radius:8px}.cf-tag-dist{background:var(--color-warm-light);color:var(--color-warm)}.cf-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.cf-card-title{margin:0;font-size:var(--text-lg);font-weight:700;line-height:1.4;color:var(--color-text-primary)}.cf-fav-btn{background:transparent;border:none;font-size:26px;color:#d1d5db;cursor:pointer;padding:0 10px;line-height:1;min-width:44px}.cf-fav-btn.active{color:#f59e0b}.cf-card-info{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.cf-card-info p{margin:0;font-size:var(--text-base);color:var(--color-text-secondary);display:flex;align-items:center;gap:8px;line-height:1.5}.cf-icon{font-size:16px;opacity:.7}.cf-card-action{width:100%;background:var(--color-accent-surface);border:1.5px solid var(--color-accent-light);color:var(--color-accent-text);font-weight:700;font-size:var(--text-base);padding:14px;border-radius:var(--radius-md);cursor:pointer;transition:background .15s;display:flex;justify-content:center;align-items:center;gap:6px;font-family:inherit}.cf-card-action:hover{background:var(--color-accent-light)}.cf-action-btn.active{background:var(--color-accent-surface);color:var(--color-accent-text);border-color:var(--color-accent)}.cf-empty-state,.cf-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.cf-spinner{width:36px;height:36px;border:3px solid var(--color-accent-light);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:18px}.cf-empty-icon{font-size:44px;margin-bottom:16px}.cf-empty-state h3{margin:0 0 8px;font-size:var(--text-lg);color:var(--color-text-primary);font-weight:700}.cf-empty-state p{margin:0;color:var(--color-text-muted);font-size:var(--text-base);line-height:var(--line-base)}.cf-sheet-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;display:flex;flex-direction:column;justify-content:flex-end;animation:fadeIn .2s ease}.cf-sheet{background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:12px 24px 32px;box-shadow:0 -4px 24px rgba(45,43,58,.12);animation:slideUp .3s cubic-bezier(.16,1,.3,1);max-height:85vh;overflow-y:auto;font-family:inherit}.cf-sheet-drag-zone{touch-action:none}.cf-sheet-handle{width:40px;height:4px;background:#e5e7eb;border-radius:2px;margin:0 auto 20px;cursor:-webkit-grab;cursor:grab}.cf-detail-head{touch-action:none}.filter-sheet h2{margin:0 0 24px;font-size:var(--text-xl);font-weight:800;color:var(--color-text-primary)}.cf-sheet-title-draggable{touch-action:none}.cf-sheet-group{margin-bottom:24px}.cf-sheet-group label{display:block;font-size:var(--text-base);font-weight:700;color:var(--color-text-primary);margin-bottom:12px}.cf-sheet-chips{display:flex;flex-wrap:wrap;gap:8px}.cf-sheet-chip{background:var(--color-bg-end);border:1.5px solid transparent;padding:10px 18px;border-radius:999px;font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;transition:all .15s;font-family:inherit;font-weight:500}.cf-sheet-chip.selected{background:var(--color-accent-surface);border-color:var(--color-accent);color:var(--color-accent-text);font-weight:700}.cf-sheet-actions{display:grid;grid-template-columns:1fr 2fr;grid-gap:12px;gap:12px;margin-top:8px}.cf-btn-primary,.cf-btn-secondary{min-height:56px;border-radius:var(--radius-md);font-size:var(--text-md);font-weight:700;cursor:pointer;border:none;font-family:inherit}.cf-btn-secondary{background:var(--color-bg-end);color:var(--color-text-secondary)}.cf-btn-primary{background:var(--color-accent);color:var(--color-text-primary)}.cf-detail-head{margin-bottom:18px}.cf-detail-head h2{margin:0 0 10px;font-size:var(--text-xl);line-height:1.3;font-weight:800;color:var(--color-text-primary)}.cf-detail-type{display:inline-block;font-size:var(--text-sm);padding:6px 12px;border-radius:8px;font-weight:600}.cf-detail-capacity,.cf-detail-type{background:var(--color-accent-surface);color:var(--color-accent-text)}.cf-detail-capacity{padding:14px;border-radius:var(--radius-md);font-size:var(--text-base);margin-bottom:20px}.cf-eval-card{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:18px;margin-bottom:20px;background:var(--color-bg-start)}.cf-eval-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}.cf-eval-grade{background:var(--color-accent);color:var(--color-text-primary);font-weight:700;padding:6px 12px;border-radius:8px;font-size:var(--text-sm)}.cf-eval-stars{font-size:20px;letter-spacing:2px}.star-on{color:#f59e0b}.star-off{color:var(--color-border)}.cf-eval-score{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:600}.cf-eval-scores{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.cf-eval-scores span{font-size:var(--text-sm);background:var(--color-surface);border:1px solid var(--color-border);padding:5px 10px;border-radius:6px;color:var(--color-text-secondary)}.cf-eval-foot{font-size:var(--text-sm);color:var(--color-text-muted)}.cf-detail-section{margin-bottom:24px}.cf-detail-section h3{font-size:var(--text-base);margin:0 0 10px;color:var(--color-text-primary);font-weight:700}.cf-detail-section p{margin:0;font-size:var(--text-base);color:var(--color-text-secondary);line-height:var(--line-base)}.cf-map-links{display:flex;gap:10px;margin-top:14px}.cf-map-link{flex:1 1;text-align:center;padding:12px;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:700;text-decoration:none;color:#fff}.cf-map-link.kakao{background:#fee500;color:#374151}.cf-map-link.naver{background:#03c75a;color:#374151}.cf-phone-link{display:block;background:var(--color-warm-light);color:var(--color-warm);padding:18px;border-radius:var(--radius-md);text-align:center;text-decoration:none;font-size:var(--text-base);font-weight:600}.cf-phone-link strong{font-size:var(--text-lg)}.cf-close-btn{width:100%}.cf-sheet-sticky-footer{position:-webkit-sticky;position:sticky;bottom:0;background:var(--color-surface);padding:8px 0 env(safe-area-inset-bottom,0)}.cf-list-header{display:flex;justify-content:space-between;align-items:center;padding:4px 2px 14px}.cf-list-count{font-size:var(--text-base);color:var(--color-text-secondary);font-weight:500}.cf-list-count strong{color:var(--color-accent-text);font-weight:700}.cf-list-page-info{font-size:var(--text-sm);color:var(--color-text-muted);background:var(--color-bg-end);padding:4px 12px;border-radius:999px;font-weight:500}.cf-sort-bar{display:flex;gap:8px;padding-bottom:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.cf-sort-bar::-webkit-scrollbar{display:none}.cf-sort-chip{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:999px;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s ease;flex-shrink:0;font-family:inherit}.cf-sort-chip:hover:not(.disabled){border-color:var(--color-accent);color:var(--color-accent-text);background:var(--color-accent-surface)}.cf-sort-chip.active{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-text-primary);box-shadow:0 3px 10px rgba(184,169,212,.35)}.cf-sort-chip.disabled{opacity:.38;cursor:not-allowed}.cf-sort-icon{font-size:14px;line-height:1}.cf-pagination{gap:6px;padding:24px 0 8px;flex-wrap:wrap}.cf-page-btn,.cf-pagination{display:flex;justify-content:center;align-items:center}.cf-page-btn{min-width:44px;height:44px;border-radius:var(--radius-sm);border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all .15s ease;padding:0 10px;font-family:inherit}.cf-page-btn:hover:not(:disabled){background:var(--color-accent-surface);border-color:var(--color-accent);color:var(--color-accent-text)}.cf-page-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-text-primary);box-shadow:0 4px 12px rgba(184,169,212,.35)}.cf-page-btn:disabled{opacity:.35;cursor:not-allowed}.cf-page-nav{font-size:18px;color:var(--color-text-muted);background:var(--color-bg-end);border-color:transparent}.cf-page-nav:hover:not(:disabled){background:var(--color-accent-light);color:var(--color-accent-text);border-color:transparent}.cf-home-link{display:flex;justify-content:center;align-items:center;gap:8px;margin:20px 20px 40px;background:var(--color-surface);border:1px solid var(--color-border);padding:18px;border-radius:var(--radius-md);text-decoration:none;color:var(--color-text-primary);font-weight:600;font-size:var(--text-base)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.fam-layout{display:flex;flex-direction:column;gap:20px;padding:0 0 40px;max-width:480px;margin:0 auto}.fam-header{padding:24px 20px 0}.fam-back-btn{background:none;border:none;font-size:14px;color:var(--color-text-secondary,#6b7280);cursor:pointer;padding:0;margin-bottom:12px;display:inline-block}.fam-title{margin:0 0 6px;font-size:28px;font-weight:800;color:var(--color-brand,sienna)}.fam-subtitle{margin:0;font-size:15px;color:var(--color-text-secondary,#6b7280);line-height:1.5}.fam-members-section{margin:0 20px;background:#fff;border-radius:16px;padding:20px;box-shadow:0 2px 12px rgba(160,82,45,.08);border:1px solid #f0e8e0}.fam-section-title{margin:0 0 16px;font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px;color:var(--color-text-primary,#111)}.fam-member-count{background:#f0e8e0;color:var(--color-primary,sienna);font-size:14px;font-weight:700;padding:2px 8px;border-radius:999px}.fam-members-loading{display:flex;justify-content:center;padding:20px 0}.fam-spinner{width:24px;height:24px;border:3px solid #f3f4f6;border-top:3px solid var(--color-primary,sienna);border-radius:50%;animation:spin 1s linear infinite}.fam-members-empty{text-align:center;padding:16px 0 4px;color:var(--color-text-secondary,#6b7280)}.fam-empty-icon{display:block;font-size:32px;margin-bottom:8px}.fam-members-empty p{margin:0 0 4px;font-size:15px;font-weight:600}.fam-empty-hint{font-size:13px!important;font-weight:400!important;color:#9ca3af}.fam-member-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.fam-member-item{display:flex;align-items:center;gap:12px;padding:12px;background:#fdf9f6;border-radius:12px;border:1px solid #f0e8e0}.fam-member-emoji{font-size:28px;line-height:1;flex-shrink:0}.fam-member-info{flex:1 1;display:flex;flex-direction:column;gap:2px}.fam-member-name{font-size:15px;font-weight:700;color:var(--color-text-primary,#111)}.fam-member-role{font-size:14px;color:var(--color-text-secondary,#6b7280)}.fam-member-badge{font-size:11px;font-weight:600;background:#e8f5e9;color:#2e7d32;padding:3px 8px;border-radius:999px;flex-shrink:0}.fam-member-action{font-size:14px;font-weight:700;border:0;background:#f5ede0;color:sienna;padding:8px 12px;border-radius:999px;flex-shrink:0;cursor:pointer}.fam-tabs{display:flex;gap:8px;padding:0 20px}.fam-tab{flex:1 1;min-height:48px;border:2px solid #e5e7eb;border-radius:12px;background:#f9fafb;color:var(--color-text-secondary,#6b7280);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.fam-tab.active{background:var(--color-primary,sienna);border-color:var(--color-primary,sienna);color:#fff}.fam-card{margin:0 20px;background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 12px rgba(160,82,45,.08);border:1px solid #f0e8e0;display:flex;flex-direction:column;gap:16px}.fam-card-title{margin:0;font-size:20px;font-weight:800;color:var(--color-brand,sienna)}.fam-card-desc{margin:-8px 0 0;font-size:14px;color:var(--color-text-secondary,#6b7280)}.fam-role-btns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.fam-role-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;border:2px solid #e5e7eb;border-radius:14px;background:#f9fafb;color:var(--color-text-secondary,#6b7280);font-size:15px;font-weight:600;line-height:1.4;text-align:center;white-space:normal;cursor:pointer;transition:all .2s}.fam-role-btn.active{border-color:var(--color-primary,sienna);background:#fffaf6;color:var(--color-primary,sienna);box-shadow:0 0 0 3px rgba(160,82,45,.1)}.fam-role-icon{font-size:28px;line-height:1}.fam-primary-btn{width:100%;min-height:52px;border:none;border-radius:12px;background:var(--color-primary,sienna);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s}.fam-primary-btn:disabled{opacity:.45;cursor:not-allowed}.fam-primary-btn:not(:disabled):active{transform:scale(.98)}.fam-code-box{background:linear-gradient(135deg,#fff9f5,#fff3eb);border:1px solid #f2d8c8;border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center}.fam-code-hint{margin:0;font-size:13px;color:var(--color-text-secondary,#6b7280)}.fam-code-display{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;flex-wrap:wrap}.fam-code-text{font-size:2.2rem;font-weight:800;letter-spacing:.15em;color:var(--color-brand,sienna);line-height:1;word-break:break-all}.fam-copy-btn{background:#fff;border:1px solid #e5e7eb;border-radius:8px;width:40px;height:40px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.fam-copy-btn:active{background:#f3f4f6}.fam-code-expiry{margin:0;font-size:12px;color:#9ca3af}.fam-share-btn{width:100%;min-height:48px;border:none;border-radius:12px;background:#111;color:#fff;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .2s,transform .15s}.fam-share-btn:active{transform:scale(.98)}.fam-code-role-desc{margin:0;font-size:13px;color:var(--color-text-secondary,#6b7280)}.fam-code-input{width:100%;font-size:1.8rem;text-align:center;letter-spacing:.15em;padding:14px 12px;border:2px solid #e5e7eb;border-radius:12px;background:#f9fafb;color:var(--color-text-primary,#111);font-weight:700;outline:none;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.fam-code-input:focus{border-color:var(--color-primary,sienna);box-shadow:0 0 0 3px rgba(160,82,45,.12);background:#fff}.fam-success-box{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;border-radius:14px;padding:28px 20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.fam-success-icon{font-size:48px;line-height:1;margin-bottom:4px}.fam-success-box h3{margin:0;font-size:22px;font-weight:800;color:#15803d}.fam-success-box p{margin:0 0 16px;font-size:14px;color:#4ade80;color:#16a34a}.fam-error-banner{margin:0 20px;background:#fff0eb;border:1px solid #ffd4c4;color:#b3261e;padding:12px 16px;border-radius:12px;font-size:14px;font-weight:500}.login-logo-wrap{margin-bottom:8px}.login-logo{width:96px;height:96px;object-fit:contain;border-radius:24px;box-shadow:0 4px 20px rgba(160,82,45,.15)}.home-brand-bar{display:flex;align-items:center;gap:8px;margin-bottom:18px;opacity:.85}.home-brand-logo{width:32px;height:32px;object-fit:contain;border-radius:8px}.home-brand-name{font-size:15px;font-weight:700;color:var(--color-brand,sienna);letter-spacing:.02em}.app-ui-layout{position:relative;min-height:calc(100vh - 48px);background:#fdfaf6;border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 12px 40px rgba(45,43,58,.06)}.app-ui-header{position:relative;background:linear-gradient(135deg,var(--color-accent) 0,#d4a882 50%,#e8cdb8 100%);padding:36px 24px 60px;color:var(--color-text-primary);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.app-ui-header.short{padding-bottom:48px}.app-ui-header-content{position:relative;z-index:1}.app-ui-title{margin:0 0 14px;font-size:var(--text-2xl);line-height:1.35;font-family:inherit;font-weight:800;color:var(--color-text-primary);white-space:pre-wrap}.app-ui-title.large{font-size:var(--text-3xl)}.app-ui-desc{margin:0;font-size:var(--text-base);color:var(--color-text-secondary);line-height:var(--line-base)}.app-ui-main-floating{position:relative;z-index:10;margin:-40px 20px 20px;display:flex;flex-direction:column;gap:16px}.mode-switch{display:flex;background:#f0e4d4;border-radius:12px;padding:3px;gap:2px}.mode-switch-btn{flex:1 1;padding:8px 16px;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;background:transparent;color:var(--color-text-muted);transition:all .2s}.mode-switch-btn.active{background:#fff;color:var(--color-primary);box-shadow:0 1px 4px rgba(0,0,0,.08)}.mode-select-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.mode-select-card,.mode-select-content{text-align:center;display:flex;flex-direction:column;align-items:center}.mode-select-card{padding:28px 24px;border-radius:20px;border:2px solid var(--color-border);background:var(--color-surface);cursor:pointer;transition:all .2s}.mode-select-card:hover{border-color:var(--color-primary);box-shadow:0 4px 16px rgba(160,82,45,.12)}.mode-select-card strong{font-size:18px;color:var(--color-text-primary);margin-bottom:4px}.mode-select-card span:last-child{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--line-base)}.speech-bubble{position:relative;background:var(--color-surface);border:2px solid var(--color-accent-light);border-radius:24px;padding:28px 24px;box-shadow:0 8px 24px rgba(184,169,212,.15);animation:bubbleIn .4s cubic-bezier(.2,.8,.4,1)}.speech-bubble:after{content:"";position:absolute;bottom:-14px;left:36px;width:24px;height:24px;background:var(--color-surface);border-right:2px solid var(--color-accent-light);border-bottom:2px solid var(--color-accent-light);transform:rotate(45deg);border-bottom-right-radius:4px}.speech-bubble-label{display:inline-block;font-size:var(--text-sm);color:var(--color-accent-text);font-weight:700;margin-bottom:12px;letter-spacing:.02em}.speech-bubble-text{margin:0;font-size:var(--text-xl);font-weight:700;line-height:1.55;color:var(--color-text-primary);word-break:keep-all}@keyframes bubbleIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.pulse-record-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;width:100%;min-height:96px;background:linear-gradient(135deg,var(--color-warm) 0,#d4956a 100%);color:#3d1a00;border:0;border-radius:28px;font-size:var(--text-xl);font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 8px 24px hsla(20,73%,66%,.35);position:relative;transition:transform .15s ease}.pulse-record-btn:before{content:"";position:absolute;inset:0;border-radius:28px;background:inherit;z-index:-1;animation:recordPulse 2s ease-out infinite}.pulse-record-btn:hover{transform:translateY(-2px)}.pulse-record-btn:active{transform:scale(.98)}.pulse-record-btn-icon{font-size:32px;line-height:1}@keyframes recordPulse{0%{box-shadow:0 0 0 0 hsla(20,73%,66%,.5)}70%{box-shadow:0 0 0 24px hsla(20,73%,66%,0)}to{box-shadow:0 0 0 0 hsla(20,73%,66%,0)}}.pill-chip{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:999px;background:var(--color-surface);border:1.5px solid var(--color-border);font-size:var(--text-base);font-weight:600;color:var(--color-text-primary);cursor:pointer;transition:all .15s ease;font-family:inherit;text-decoration:none}.pill-chip:hover{background:var(--color-surface-alt);transform:translateY(-1px)}.pill-chip-icon{font-size:18px}.pill-chip-row{display:flex;flex-wrap:wrap;gap:10px}.recording-modal-backdrop{position:fixed;inset:0;background:rgba(45,43,58,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:stretch;justify-content:center;animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.recording-modal{width:100%;max-width:480px;background:linear-gradient(180deg,#fdfaf6,#f5ede0);display:flex;flex-direction:column;padding:24px 24px 40px;position:relative;animation:modalSlideUp .3s cubic-bezier(.2,.8,.4,1)}@keyframes modalSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.recording-modal-close{position:absolute;top:16px;left:16px;min-width:64px;height:48px;padding:0 16px;border-radius:14px;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);font-size:16px;font-weight:700;cursor:pointer;font-family:inherit;z-index:100;display:flex;align-items:center;justify-content:center;gap:4px;box-shadow:0 4px 12px rgba(45,43,58,.1)}.recording-modal-close:hover{background:var(--color-bg-end)}.recording-modal-close:active{transform:scale(.96)}.recording-modal-close:disabled{opacity:.4;cursor:not-allowed}.recording-modal-question{margin-top:80px;padding:28px 24px;background:var(--color-surface);border-radius:24px;border:2px solid var(--color-accent-light);box-shadow:0 8px 24px rgba(184,169,212,.12)}.recording-modal-question-label{margin:0 0 12px;font-size:var(--text-sm);color:var(--color-accent-text);font-weight:700}.recording-modal-question-text{margin:0;font-size:var(--text-xl);font-weight:700;line-height:1.55;color:var(--color-text-primary);word-break:keep-all}.recording-modal-main{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 0;gap:16px}.recording-modal-hint{margin:0;font-size:var(--text-base);color:var(--color-text-secondary);text-align:center}.recording-modal-mic-btn{width:160px;height:160px;border-radius:50%;border:0;background:linear-gradient(135deg,var(--color-warm) 0,#d4956a 100%);color:#3d1a00;font-size:64px;cursor:pointer;box-shadow:0 12px 32px hsla(20,73%,66%,.4);transition:transform .15s ease;display:flex;align-items:center;justify-content:center;position:relative;font-family:inherit}.recording-modal-mic-btn:before{content:"";position:absolute;inset:-4px;border-radius:50%;background:inherit;z-index:-1;animation:recordPulse 2s ease-out infinite}.recording-modal-mic-btn:active{transform:scale(.96)}.pulse-mic-btn{position:relative;transition:transform .15s ease}.pulse-mic-btn:before{content:"";position:absolute;inset:-4px;border-radius:50%;background:inherit;z-index:-1;animation:recordPulse 2s ease-out infinite}.pulse-mic-btn:active{transform:scale(.96)}.recording-modal-recording-indicator{display:flex;align-items:center;gap:10px;font-size:var(--text-base);font-weight:700;color:#e74c3c}.recording-modal-dot{width:14px;height:14px;border-radius:50%;background:#e74c3c;animation:dotPulse 1.2s ease-in-out infinite}@keyframes dotPulse{0%,to{opacity:1}50%{opacity:.3}}.recording-modal-timer{margin:8px 0;font-size:64px;font-weight:800;color:var(--color-text-primary);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:-2px}.recording-modal-timer-small{margin:0;font-size:var(--text-xl);color:var(--color-text-secondary);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.recording-modal-stop-btn{width:96px;height:96px;border-radius:50%;border:0;background:#e74c3c;color:#fff;font-size:36px;cursor:pointer;box-shadow:0 8px 24px rgba(231,76,60,.4);display:flex;align-items:center;justify-content:center;font-family:inherit}.recording-modal-stop-btn:active{transform:scale(.96)}.recording-modal-ready-msg{margin:0;font-size:var(--text-xl);font-weight:700;color:var(--color-text-primary)}.recording-modal-actions{width:100%;display:flex;flex-direction:column;gap:10px;margin-top:20px}.recording-modal-success-emoji{margin:0;font-size:80px}.recording-modal-success-msg{margin:0;font-size:var(--text-xl);font-weight:700;color:var(--color-text-primary);text-align:center}.icon-btn{width:44px;height:44px;border:0;background:hsla(0,0%,100%,.2);color:#fff;font-size:20px;display:inline-flex;transition:background .15s ease}.icon-btn:hover{background:hsla(0,0%,100%,.35)}.page-layout{min-height:calc(100vh - 80px);padding:20px 20px 40px;display:flex;flex-direction:column;gap:24px}.page-header{display:flex;justify-content:space-between;align-items:center;padding:4px 0 8px}.page-header__brand{display:flex;align-items:center;gap:10px}.page-header__logo{width:36px;height:36px;border-radius:10px}.page-header__title{font-size:var(--text-md);font-weight:800;color:var(--color-primary);margin:0}.page-header__actions{display:flex;gap:8px;align-items:center}.icon-btn{width:48px;height:48px;border-radius:14px;border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:inherit;transition:background .15s,border-color .15s,box-shadow .15s;box-shadow:0 1px 4px rgba(45,43,58,.06);color:var(--color-text-secondary)}.icon-btn:hover{background:var(--color-surface-alt);border-color:var(--color-border-accent)}.icon-btn:active{background:var(--color-accent-light)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;box-shadow:0 2px 12px rgba(45,43,58,.06)}.card--accent{background:var(--color-accent-surface);border-color:var(--color-border-accent)}.card--warm{background:var(--color-warm-light);border-color:hsla(20,73%,66%,.25)}.card--primary{background:linear-gradient(135deg,var(--color-primary) 0,#9b6850 100%);color:#fff;border:none}.card--clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.card--clickable:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(45,43,58,.1)}.card--clickable:active{transform:translateY(0)}.quick-link-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.quick-link-card{text-align:left;font-family:inherit;background:none;border:none;padding:0;cursor:pointer}.quick-link-card__icon{font-size:var(--text-2xl);margin-bottom:8px}.quick-link-card__label{font-weight:700;font-size:var(--text-sm);color:var(--color-text-primary);margin-bottom:2px}.quick-link-card__sub{font-size:var(--text-xs);color:var(--color-text-muted)}.today-done-card{text-align:center}.today-done-card__icon{margin:0;font-size:var(--text-2xl)}.today-done-card__title{margin:8px 0 4px;font-weight:700;font-size:var(--text-base);color:var(--color-text-primary)}.today-done-card__sub{margin:0}.section-title,.today-done-card__sub{font-size:var(--text-sm);color:var(--color-text-muted)}.section-title{font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin:0 0 12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:52px;padding:0 24px;border-radius:var(--radius-md);font-family:inherit;font-size:var(--text-base);font-weight:700;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s;border:none;outline:none;width:100%}.btn:active{transform:scale(.98)}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn--primary{background:var(--color-primary);color:#fff;box-shadow:0 4px 16px rgba(122,80,64,.3)}.btn--primary:hover{background:var(--color-primary-hover);box-shadow:0 6px 20px rgba(122,80,64,.4)}.btn--warm{background:var(--color-warm);color:#fff;box-shadow:0 4px 16px rgba(184,90,44,.35);font-size:var(--text-lg);min-height:64px;border-radius:var(--radius-xl)}.btn--warm:hover{background:#9c4a1f;box-shadow:0 6px 20px rgba(184,90,44,.45)}.btn--warm:disabled{background:var(--color-border);box-shadow:none;color:var(--color-text-muted);cursor:not-allowed}.btn--ghost{background:none;color:var(--color-text-secondary);border:1.5px solid var(--color-border)}.btn--ghost:hover{background:var(--color-surface-alt);border-color:var(--color-border-accent)}.btn--sm{min-height:44px;padding:0 16px;font-size:var(--text-sm);border-radius:var(--radius-sm);width:auto}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:700;letter-spacing:.03em}.badge--accent{background:var(--color-accent-light);color:var(--color-accent-text)}.badge--warm{background:var(--color-warm-light);color:#c0632e}.badge--success{background:#e8f5e9;color:#2e7d32}.badge--muted{background:var(--color-surface-alt);color:var(--color-text-muted)}.streak-bar{display:flex;gap:6px;align-items:flex-end}.streak-bar__day{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:6px}.streak-bar__dot{width:100%;max-width:36px;aspect-ratio:1;border-radius:10px;transition:background .2s,transform .15s}.streak-bar__dot--recorded{background:var(--color-primary)}.streak-bar__dot--today{box-shadow:0 0 0 2px var(--color-warm),0 2px 8px hsla(20,73%,66%,.35);transform:scale(1.1)}.streak-bar__dot--empty{background:var(--color-border)}.streak-bar__label{font-size:11px;font-weight:600;color:var(--color-text-muted)}.streak-bar__label--today{color:var(--color-warm);font-weight:700}.question-card{background:linear-gradient(135deg,#fff8f4,#faf4fb);border:1.5px solid var(--color-border-accent);border-radius:var(--radius-xl);padding:24px 20px;box-shadow:0 4px 20px rgba(180,122,82,.1)}.question-card__label{font-size:var(--text-xs);font-weight:700;color:var(--color-brand);letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px}.question-card__text{font-size:var(--text-xl);font-weight:700;color:var(--color-text-primary);line-height:1.45;margin:0 0 4px;word-break:keep-all}.login-loading{min-height:calc(100vh - 96px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:24px;background:linear-gradient(180deg,var(--color-bg-start) 0,var(--color-bg-end) 100%)}.login-loading__logo-wrap{width:88px;height:88px;border-radius:22px;overflow:hidden;box-shadow:0 8px 24px rgba(180,122,82,.15);animation:login-loading-breath 2.4s ease-in-out infinite}.login-loading__logo{width:100%;height:100%;display:block;object-fit:cover}.login-loading__title{font-size:var(--text-2xl);font-weight:800;color:var(--color-text-primary);margin:12px 0 0;letter-spacing:-.01em}.login-loading__sub{font-size:var(--text-base);color:var(--color-text-secondary);margin:0;text-align:center;word-break:keep-all}.login-loading__dots{display:flex;gap:8px;margin-top:8px}.login-loading__dots span{width:8px;height:8px;border-radius:50%;background:var(--color-warm);opacity:.4;animation:login-loading-dot 1.4s ease-in-out infinite}.login-loading__dots span:nth-child(2){animation-delay:.2s}.login-loading__dots span:nth-child(3){animation-delay:.4s}@keyframes login-loading-breath{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes login-loading-dot{0%,80%,to{opacity:.4;transform:scale(1)}40%{opacity:1;transform:scale(1.3)}}.question-card__text--answered{color:var(--color-text-muted);text-decoration:line-through}.question-card__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:8px 0 0}.timeline-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:0 1px 8px rgba(45,43,58,.05);transition:box-shadow .15s}.timeline-item:hover{box-shadow:0 3px 16px rgba(45,43,58,.1)}.timeline-item__question{font-size:var(--text-sm);font-weight:600;color:var(--color-accent-text);margin-bottom:8px;word-break:keep-all}.timeline-item__transcript{font-size:var(--text-base);color:var(--color-text-primary);line-height:1.7;word-break:keep-all;margin:0}.timeline-item__meta{display:flex;align-items:center;justify-content:space-between;margin-top:12px;gap:8px}.timeline-item__time{font-size:var(--text-xs);color:var(--color-text-muted)}.timeline-item__actions{display:flex;gap:8px;align-items:center}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;text-align:center}.empty-state__icon{font-size:56px;line-height:1;margin-bottom:4px}.empty-state__title{font-size:var(--text-lg);font-weight:700;color:var(--color-text-primary);margin:0;word-break:keep-all}.empty-state__desc{font-size:var(--text-sm);color:var(--color-text-muted);margin:0;line-height:1.65;word-break:keep-all}.member-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:box-shadow .15s,background .15s;width:100%;text-align:left;font-family:inherit}.member-card:hover{box-shadow:0 4px 16px rgba(45,43,58,.08);background:var(--color-surface-alt)}.member-card__avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--color-accent-light),var(--color-warm-light));display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;border:2px solid var(--color-border-accent)}.member-card__info{flex:1 1;min-width:0}.member-card__name{font-size:var(--text-md);font-weight:700;color:var(--color-text-primary);margin:0 0 4px}.member-card__sub{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.greeting-section{padding:4px 0}.greeting-section__hello{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500;margin:0 0 4px}.greeting-section__name{font-size:var(--text-2xl);font-weight:800;color:var(--color-text-primary);margin:0 0 2px;line-height:1.25}.greeting-section__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:6px 0 0}.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);background:var(--color-text-primary);color:#fff;padding:12px 20px;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;z-index:200;white-space:nowrap;box-shadow:0 4px 20px rgba(0,0,0,.2);animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.spinner{width:24px;height:24px;border:2.5px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}.spinner--sm{width:18px;height:18px;border-width:2px}.spinner--lg{width:36px;height:36px;border-width:3px}@keyframes spin{to{transform:rotate(1turn)}}.audio-player{width:100%;height:44px;border-radius:var(--radius-sm);accent-color:var(--color-primary);margin:8px 0 0}.reaction-btn{display:inline-flex;align-items:center;gap:5px;padding:10px 14px;border-radius:22px;border:1.5px solid var(--color-border);background:none;font-family:inherit;font-size:var(--text-sm);font-weight:600;color:var(--color-text-muted);cursor:pointer;transition:all .15s;min-height:44px;min-width:44px}.reaction-btn:hover{border-color:var(--color-border-accent);background:var(--color-accent-light);color:var(--color-accent-text)}.reaction-btn--active{border-color:var(--color-warm);background:var(--color-warm-light);color:#c0632e}.input-field{width:100%;min-height:52px;padding:14px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:var(--text-base);color:var(--color-text-primary);background:var(--color-surface);outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.input-field:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(122,80,64,.12)}.input-field::placeholder{color:var(--color-text-muted)}.date-divider{display:flex;align-items:center;gap:10px;margin:8px 0}.date-divider__line{flex:1 1;height:1px;background:var(--color-border)}.date-divider__text{font-size:var(--text-xs);font-weight:700;color:var(--color-text-muted);white-space:nowrap;letter-spacing:.04em}.scroll-stack{display:flex;flex-direction:column;gap:12px}.error-msg{background:#fff0f0;border:1px solid #fcc;color:#c0392b;border-radius:var(--radius-sm)}.error-msg,.success-msg{padding:12px 16px;font-size:var(--text-sm);font-weight:600;word-break:keep-all}.success-msg{background:#f0fff4;border:1px solid #c3e6cb;color:#1e7e34;border-radius:var(--radius-sm)}.connect-banner{background:linear-gradient(160deg,#fff8f2 0,var(--color-accent-surface) 60%,#fff0e6 100%);border:1.5px solid var(--color-border-accent);border-radius:var(--radius-xl);padding:32px 20px 28px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:0 2px 16px rgba(180,122,82,.08)}.connect-banner__illustration{margin-bottom:4px;filter:drop-shadow(0 4px 12px rgba(180,122,82,.15))}.connect-banner__title{font-size:var(--text-lg);font-weight:800;color:var(--color-text-primary);margin:0;word-break:keep-all}.connect-banner__desc{font-size:var(--text-sm);color:var(--color-text-muted);margin:0;line-height:1.65;word-break:keep-all}.connect-banner__steps{display:flex;flex-direction:column;gap:6px;margin:4px 0 0;width:100%;max-width:220px}.connect-banner__step{font-size:var(--text-xs);color:var(--color-accent-text);background:var(--color-accent-light);border-radius:8px;padding:6px 12px;font-weight:600;text-align:left;word-break:keep-all}.streak-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:linear-gradient(135deg,#fff4e8,#fff0e0);border:1.5px solid hsla(20,73%,66%,.3);border-radius:20px;font-size:var(--text-sm);font-weight:800;color:#c0632e}.toggle-switch{position:relative;display:inline-block;width:52px;height:30px;flex-shrink:0}.toggle-switch input{position:absolute;opacity:0;width:100%;height:100%;top:0;left:0;margin:0;cursor:pointer;z-index:1}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#d4d0dd;transition:.22s;border-radius:30px}.toggle-slider:before{content:"";position:absolute;height:24px;width:24px;left:3px;bottom:3px;background-color:#fff;transition:.22s;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.15)}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(22px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}