*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-0: #0a0a0d;--bg-1: #111114;--bg-2: #18181c;--bg-3: #222228;--bg-hover: #28282f;--bg-card: #151518;--border: #252530;--border-hover: #35354a;--text: #d4d4d8;--text-secondary: #8b8b95;--text-tertiary: #52525b;--text-heading: #fafafa;--accent: #5eead4;--accent-dim: rgba(94, 234, 212, .1);--purple: #a78bfa;--purple-dim: rgba(167, 139, 250, .1);--red: #f87171;--red-dim: rgba(248, 113, 113, .1);--orange: #fbbf24;--orange-dim: rgba(251, 191, 36, .1);--green: #4ade80;--green-dim: rgba(74, 222, 128, .1);--blue: #60a5fa;--blue-dim: rgba(96, 165, 250, .1);--pink: #f472b6;--pink-dim: rgba(244, 114, 182, .1);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "Cascadia Code", "Fira Code", "SF Mono", Consolas, monospace;--sidebar-w: 220px;--sidebar-collapsed: 56px;--radius: 10px;--radius-sm: 6px;--radius-full: 999px;--transition: .2s cubic-bezier(.4, 0, .2, 1);--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 24px rgba(0,0,0,.5)}:root.dim{--bg-0: #1a1a20;--bg-1: #202028;--bg-2: #282830;--bg-3: #323240;--bg-hover: #3a3a48;--bg-card: #242430;--border: #3a3a4a;--border-hover: #4a4a5a;--text: #c8c8d0;--text-secondary: #9090a0;--text-tertiary: #606070;--text-heading: #ebebf0;--accent: #5eead4;--accent-dim: rgba(94, 234, 212, .1);--purple: #a78bfa;--purple-dim: rgba(167, 139, 250, .1);--red: #f87171;--red-dim: rgba(248, 113, 113, .1);--orange: #fbbf24;--orange-dim: rgba(251, 191, 36, .1);--green: #4ade80;--green-dim: rgba(74, 222, 128, .1);--blue: #60a5fa;--blue-dim: rgba(96, 165, 250, .1);--pink: #f472b6;--pink-dim: rgba(244, 114, 182, .1);--shadow-sm: 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 12px rgba(0,0,0,.25);--shadow-lg: 0 8px 24px rgba(0,0,0,.35)}:root.light{--bg-0: #f5f5f7;--bg-1: #ffffff;--bg-2: #f0f0f3;--bg-3: #e5e5ea;--bg-hover: #dddde2;--bg-card: #ffffff;--border: #e0e0e5;--border-hover: #ccccd2;--text: #1c1c1e;--text-secondary: #6b6b75;--text-tertiary: #a0a0aa;--text-heading: #09090b;--accent: #0d9488;--accent-dim: rgba(13, 148, 136, .08);--purple: #7c3aed;--purple-dim: rgba(124, 58, 237, .06);--red: #ef4444;--red-dim: rgba(239, 68, 68, .06);--orange: #d97706;--orange-dim: rgba(217, 119, 6, .06);--green: #16a34a;--green-dim: rgba(22, 163, 74, .06);--blue: #2563eb;--blue-dim: rgba(37, 99, 235, .06);--pink: #db2777;--pink-dim: rgba(219, 39, 119, .06);--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.12)}html{font-size:14px}body{font-family:var(--font);background:var(--bg-0);color:var(--text);line-height:1.5;min-height:100vh;overflow:hidden;-webkit-font-smoothing:antialiased}#app{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);height:100vh;display:flex;flex-direction:column;background:var(--bg-1);border-right:1px solid var(--border);transition:width var(--transition),min-width var(--transition);overflow:hidden;z-index:50}.sidebar.collapsed{width:var(--sidebar-collapsed);min-width:var(--sidebar-collapsed)}.sidebar-top{display:flex;align-items:center;gap:10px;padding:16px 14px;border-bottom:1px solid var(--border)}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);flex-shrink:0}.sidebar-toggle:hover{background:var(--bg-hover);color:var(--text)}.sidebar-logo{font-size:.95rem;font-weight:700;color:var(--text-heading);white-space:nowrap;opacity:1;transition:opacity var(--transition)}.sidebar.collapsed .sidebar-logo{opacity:0;width:0}.sidebar-nav{flex:1;padding:8px;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition);border:none;background:transparent;width:100%;text-align:left;font-family:var(--font)}.sidebar-link:hover{background:var(--bg-hover);color:var(--text)}.sidebar-link.active{background:var(--accent-dim);color:var(--accent)}.sidebar-link svg{flex-shrink:0}.sidebar-label{white-space:nowrap;overflow:hidden;transition:opacity var(--transition)}.sidebar.collapsed .sidebar-label{opacity:0;width:0}.sidebar-bottom{padding:8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:2px}.main{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg-0)}.view{display:none;padding:28px 36px;max-width:960px;margin:0 auto}.view.active{display:block}.view-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.view-header h1{font-size:1.5rem;font-weight:700;color:var(--text-heading);letter-spacing:-.02em}.view-header-actions{margin-left:auto;display:flex;gap:6px}.news-count,.counter{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:22px;padding:0 8px;border-radius:var(--radius-full);background:var(--accent-dim);color:var(--accent);font-size:.75rem;font-weight:600}.btn-icon-sm{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition)}.btn-icon-sm:hover{background:var(--bg-hover);color:var(--text)}.btn-icon-sm.spinning svg{animation:spin .8s linear infinite}.filter-bar{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;height:30px;padding:0 14px;border-radius:var(--radius-full);font-family:var(--font);font-size:.8rem;font-weight:500;border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none}.chip:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text)}.chip.active{background:var(--accent);color:#0c0c0f;border-color:var(--accent);font-weight:600}.light .chip.active{color:#fff}.source-bar{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}.source-chip{display:inline-flex;align-items:center;gap:5px;height:28px;padding:0 10px;border-radius:var(--radius-full);font-family:var(--font);font-size:.75rem;font-weight:500;border:1px solid var(--border);background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none}.source-chip:hover{border-color:var(--border-hover);color:var(--text-secondary)}.source-chip.active{background:color-mix(in srgb,var(--source-color) 12%,transparent);border-color:color-mix(in srgb,var(--source-color) 40%,transparent);color:var(--source-color)}.source-chip-icon{font-size:.85rem;line-height:1}.source-chip-name{white-space:nowrap}.feed{display:flex;flex-direction:column;gap:2px;transition:opacity var(--transition)}.feed.loading{opacity:.35;pointer-events:none}.feed-group-header{display:flex;align-items:center;gap:10px;padding:14px 0 8px;font-size:.7rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em}.feed-group-header:after{content:"";flex:1;height:1px;background:var(--border)}.feed-group-count{font-size:.65rem;padding:1px 6px;border-radius:var(--radius-full);background:var(--bg-3);color:var(--text-tertiary)}.news-item{display:flex;gap:14px;padding:14px 16px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:all .18s ease;position:relative;margin-bottom:8px}.news-item:hover{background:var(--bg-2);border-color:var(--border-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.news-item.priority-high{border-left:3px solid var(--red)}.news-item.priority-medium{border-left:3px solid var(--orange)}.news-item.priority-low{border-left:3px solid transparent}.news-thumb{width:120px;height:80px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;background:var(--bg-3)}.news-thumb img{width:100%;height:100%;object-fit:cover;display:block}.news-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.news-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.news-source-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:.7rem;font-weight:600;background:color-mix(in srgb,var(--source-color) 12%,transparent);color:var(--source-color);white-space:nowrap}.news-time{font-size:.72rem;color:var(--text-tertiary)}.news-multi-source{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--radius-full);font-size:.65rem;font-weight:600;background:var(--purple-dim);color:var(--purple);white-space:nowrap}.news-title{font-size:.92rem;font-weight:600;color:var(--text-heading);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.news-summary{font-size:.8rem;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.news-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:2px;flex-wrap:wrap}.news-stats{display:flex;align-items:center;gap:10px}.news-stat{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;color:var(--text-tertiary)}.news-stat svg{opacity:.7}.news-score-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:18px;padding:0 5px;border-radius:var(--radius-sm);font-size:.65rem;font-weight:700}.news-score-badge.high{background:var(--red-dim);color:var(--red)}.news-score-badge.medium{background:var(--orange-dim);color:var(--orange)}.news-score-badge.low{background:var(--bg-3);color:var(--text-tertiary)}.news-tags{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.news-cat-tag{display:inline-flex;align-items:center;padding:1px 7px;border-radius:var(--radius-full);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;background:color-mix(in srgb,var(--cat-color) 12%,transparent);color:var(--cat-color)}.news-tag{display:inline-flex;align-items:center;padding:1px 7px;border-radius:var(--radius-full);font-size:.62rem;font-weight:500;background:var(--bg-3);color:var(--text-secondary)}.news-item.compact-mode{padding:8px 12px;margin-bottom:0;border-radius:0;border:none;border-bottom:1px solid var(--border);background:transparent;gap:10px}.news-item.compact-mode:hover{background:var(--bg-2);transform:none;box-shadow:none}.news-item.compact-mode .news-thumb,.news-item.compact-mode .news-summary{display:none}.news-item.compact-mode .news-title{font-size:.85rem;font-weight:500;-webkit-line-clamp:1}.news-item.compact-mode .news-footer{margin-top:0}.news-detail{display:none;padding:0}.news-item.expanded .news-detail{display:flex;align-items:center;gap:8px;padding-top:8px;margin-top:4px;border-top:1px solid var(--border)}.news-item.expanded{background:var(--bg-2);border-color:var(--border-hover)}.news-detail-link{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;color:var(--accent);text-decoration:none;font-weight:500;padding:4px 12px;border-radius:var(--radius-sm);background:var(--accent-dim);transition:all var(--transition)}.news-detail-link:hover{background:color-mix(in srgb,var(--accent) 20%,transparent)}.feed-empty{padding:64px 0;text-align:center;color:var(--text-tertiary)}.feed-empty-icon{font-size:2.5rem;margin-bottom:12px}.projects-list{display:flex;flex-direction:column;gap:10px}.project-card{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.project-card:hover{background:var(--bg-2);border-color:var(--border-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.project-icon{font-size:1.6rem;flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);background:var(--bg-3)}.project-info{flex:1;min-width:0}.project-name{font-size:.95rem;font-weight:600;color:var(--text-heading)}.project-desc{font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.project-status{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.project-status:before{content:"";width:6px;height:6px;border-radius:50%}.project-status.active{background:var(--green-dim);color:var(--green)}.project-status.active:before{background:var(--green);box-shadow:0 0 6px var(--green)}.project-status.paused{background:var(--orange-dim);color:var(--orange)}.project-status.paused:before{background:var(--orange)}.project-status.archived{background:var(--bg-3);color:var(--text-tertiary)}.project-status.archived:before{background:var(--text-tertiary)}.project-arrow{color:var(--text-tertiary);transition:transform var(--transition)}.project-card:hover .project-arrow{transform:translate(3px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:300}.modal-backdrop.open{opacity:1;pointer-events:auto}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);width:480px;max-width:90vw;max-height:80vh;background:var(--bg-1);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);z-index:310;display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:1.05rem;font-weight:600;color:var(--text-heading)}.modal-body{flex:1;overflow-y:auto;padding:20px 24px}.settings-section{margin-bottom:24px}.settings-section-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:10px}.settings-sources{display:flex;flex-direction:column;gap:6px}.settings-toggle{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition)}.settings-toggle:hover{background:var(--bg-hover)}.settings-toggle input[type=checkbox]{display:none}.toggle-switch{width:32px;height:18px;border-radius:9px;background:var(--bg-3);position:relative;transition:background var(--transition);flex-shrink:0}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--text-tertiary);transition:all var(--transition)}.settings-toggle input:checked+.toggle-switch{background:var(--accent)}.settings-toggle input:checked+.toggle-switch:after{left:16px;background:#0a0a0d}.settings-toggle-icon{font-size:1rem}.settings-toggle-label{font-size:.85rem;color:var(--text)}.settings-interests{display:flex;flex-wrap:wrap;gap:6px}.settings-chip-toggle{cursor:pointer}.settings-chip-toggle input{display:none}.settings-chip-label{display:inline-flex;align-items:center;height:30px;padding:0 12px;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;border:1px solid var(--border);color:var(--text-secondary);transition:all var(--transition)}.settings-chip-toggle:hover .settings-chip-label{border-color:var(--border-hover);color:var(--text)}.settings-chip-toggle input:checked+.settings-chip-label{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);font-weight:600}.settings-row{display:flex;gap:8px;flex-wrap:wrap}.settings-radio{cursor:pointer;display:flex;align-items:center;gap:6px}.settings-radio input{display:none}.settings-radio span{display:inline-flex;align-items:center;height:30px;padding:0 14px;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;border:1px solid var(--border);color:var(--text-secondary);transition:all var(--transition)}.settings-radio:hover span{border-color:var(--border-hover);color:var(--text)}.settings-radio input:checked+span{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);font-weight:600}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:200}.drawer-backdrop.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;width:480px;max-width:90vw;height:100vh;background:var(--bg-1);border-left:1px solid var(--border);transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:210;display:flex;flex-direction:column;overflow:hidden}.drawer.open{transform:translate(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.drawer-title{font-size:1.1rem;font-weight:600;color:var(--text-heading)}.drawer-body{flex:1;overflow-y:auto;padding:24px}.drawer-section{margin-bottom:24px}.drawer-section-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:8px}.drawer-field{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.85rem}.drawer-field-label{color:var(--text-secondary);min-width:80px;font-weight:500}.drawer-field-value{color:var(--text);font-family:var(--font-mono);font-size:.8rem;word-break:break-all}.drawer-tags{display:flex;flex-wrap:wrap;gap:6px}.drawer-tag{padding:3px 10px;border-radius:var(--radius-full);background:var(--purple-dim);color:var(--purple);font-size:.75rem;font-weight:500}.drawer-links{display:flex;flex-direction:column;gap:4px}.drawer-link{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--bg-2);color:var(--accent);text-decoration:none;font-size:.85rem;font-weight:500;transition:background var(--transition)}.drawer-link:hover{background:var(--bg-3)}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.feed>.news-item,.projects-list>*{animation:slideUp .35s ease both}.feed>*:nth-child(1){animation-delay:0s}.feed>*:nth-child(2){animation-delay:.02s}.feed>*:nth-child(3){animation-delay:.04s}.feed>*:nth-child(4){animation-delay:.06s}.feed>*:nth-child(5){animation-delay:.08s}.feed>*:nth-child(6){animation-delay:.1s}.feed>*:nth-child(7){animation-delay:.12s}.feed>*:nth-child(8){animation-delay:.14s}.feed>*:nth-child(9){animation-delay:.16s}.feed>*:nth-child(10){animation-delay:.18s}.feed>*:nth-child(n+11){animation-delay:.2s}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.category-bar{margin-bottom:8px}.cat-chip{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:var(--radius-full);font-family:var(--font);font-size:.72rem;font-weight:500;border:1px solid var(--border);background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none}.cat-chip:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-secondary)}.cat-chip.active{background:var(--purple-dim);border-color:var(--purple);color:var(--purple);font-weight:600}.news-loading{display:flex;align-items:center;gap:12px;padding:10px 0;margin-bottom:8px}.loading-bar{flex:1;height:3px;background:var(--bg-3);border-radius:2px;overflow:hidden}.loading-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease;width:0%}.loading-text{font-size:.7rem;color:var(--text-tertiary);white-space:nowrap}.news-detail-body{display:flex;flex-direction:column;gap:8px;flex:1}.news-detail-summary{font-size:.82rem;color:var(--text-secondary);line-height:1.55;margin:0}.news-detail-stats{display:flex;align-items:center;gap:16px;font-size:.75rem;color:var(--text-tertiary)}.news-detail-stats strong{color:var(--text);font-weight:600}.news-detail-source{color:var(--text-secondary);font-weight:500}.news-detail-tags{display:flex;flex-wrap:wrap;gap:4px}.news-item.expanded .news-detail{display:flex;flex-direction:column;gap:10px;padding-top:10px;margin-top:6px;border-top:1px solid var(--border)}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:90;display:none}.sidebar-backdrop.open{opacity:1;pointer-events:auto}@media(max-width:768px){.sidebar{position:fixed;left:0;z-index:100;transform:translate(0);transition:transform var(--transition),width var(--transition),min-width var(--transition)}.sidebar.collapsed{transform:translate(calc(-1 * var(--sidebar-w)))}.sidebar-backdrop{display:block}.main{margin-left:0!important}.view{padding:20px 16px}.drawer{width:100vw;max-width:100vw}.modal{width:95vw;max-height:85vh}.news-thumb{width:80px;height:56px}.source-bar{display:none}.news-item{padding:12px;gap:10px}.news-title{font-size:.88rem}.news-footer{gap:8px}.news-tags{display:none}.filter-bar{gap:4px}.chip{height:28px;padding:0 10px;font-size:.75rem}.cat-chip{height:24px;padding:0 8px;font-size:.68rem}.view-header h1{font-size:1.25rem}}@media(max-width:480px){.view{padding:16px 12px}.news-thumb{display:none}.news-item{padding:10px}.modal{width:100vw;max-width:100vw;border-radius:14px 14px 0 0;top:auto;bottom:0;transform:translate(-50%) translateY(100%)}.modal.open{transform:translate(-50%) translateY(0)}}
