*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:system-ui,-apple-system,sans-serif;background:#f5f5f5;color:#1a1a1a;-webkit-tap-highlight-color:transparent}input,select,textarea{font-size:max(16px,1em)}button{touch-action:manipulation}.auth-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1rem}.auth-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001f;padding:2rem;width:100%;max-width:380px}.auth-card h1{margin:0 0 .25rem;font-size:1.5rem}.auth-card h2{margin:0 0 1.5rem;font-size:1.1rem;font-weight:500;color:#555}.auth-card form{display:flex;flex-direction:column;gap:.75rem}.auth-card label{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;font-weight:500}.auth-card input{padding:.5rem .75rem;border:1px solid #ccc;border-radius:6px;font-size:1rem;width:100%}.auth-card input:focus{outline:2px solid #4f6ef7;border-color:transparent}.auth-card button[type=submit]{margin-top:.5rem;padding:.65rem;background:#4f6ef7;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer}.auth-card button[type=submit]:disabled{opacity:.6;cursor:default}.form-error{margin:0;color:#d32f2f;font-size:.875rem}.auth-switch{margin:1rem 0 0;font-size:.875rem;text-align:center}.link-btn{background:none;border:none;color:#4f6ef7;cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.top-nav{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:10}.nav-brand{font-weight:700;font-size:1.1rem;margin-right:auto}.nav-user{font-size:.875rem;color:#555}.main-content{padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom));max-width:640px;margin:0 auto}.boards-page{padding:1rem;max-width:480px;margin:0 auto}.boards-page h1{margin:0 0 1.5rem}.boards-list ul{list-style:none;margin:0 0 1.5rem;padding:0;display:flex;flex-direction:column;gap:.5rem}.board-item{width:100%;text-align:left;padding:.75rem 1rem;background:#fff;border:1px solid #e0e0e0;border-radius:8px;font-size:1rem;cursor:pointer}.board-item:hover{background:#f0f4ff;border-color:#4f6ef7}.boards-actions{display:flex;gap:.75rem;flex-wrap:wrap}.boards-actions button,.boards-form button[type=submit]{padding:.6rem 1.2rem;background:#4f6ef7;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer}.boards-form button[type=button]{padding:.6rem 1.2rem;background:#eee;color:#333;border:none;border-radius:6px;font-size:.95rem;cursor:pointer}.boards-form{display:flex;flex-direction:column;gap:.75rem;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.25rem}.boards-form h2{margin:0 0 .5rem}.boards-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;font-weight:500}.boards-form input{padding:.5rem .75rem;border:1px solid #ccc;border-radius:6px;font-size:1rem}.form-row{display:flex;gap:.75rem}.btn{padding:.5rem .9rem;border:1px solid #ccc;border-radius:6px;background:#fff;font-size:.875rem;cursor:pointer;white-space:nowrap}.btn:hover{background:#f0f0f0}.btn--primary{background:#4f6ef7;color:#fff;border-color:#4f6ef7}.btn--primary:hover{background:#3a59e0}.btn--sm{padding:.35rem .7rem;font-size:.8rem;min-height:36px}.btn--danger{background:#d32f2f;color:#fff;border-color:#d32f2f}.task-list-page{display:flex;flex-direction:column;gap:.75rem}.task-list-toolbar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.board-title{font-weight:600;font-size:1.1rem;margin-right:auto}.board-select{font-size:.95rem;padding:.35rem .6rem;border:1px solid #ccc;border-radius:6px;margin-right:auto}.search-bar{display:flex;align-items:center;gap:.5rem}.search-bar input{flex:1;padding:.5rem .75rem;border:1px solid #ccc;border-radius:6px;font-size:.9rem}.search-bar input:focus{outline:2px solid #4f6ef7;border-color:transparent}.search-bar__clear{white-space:nowrap;font-size:.875rem}.sort-bar{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#555}.sort-btn{padding:.25rem .6rem;border:1px solid #ccc;border-radius:4px;background:#fff;font-size:.8rem;cursor:pointer}.sort-btn--active{background:#4f6ef7;color:#fff;border-color:#4f6ef7}.task-list{display:flex;flex-direction:column;gap:.6rem}.loading-msg,.empty-msg{color:#888;font-size:.9rem;text-align:center;padding:2rem 0}.task-card{background:#fff;border:1px solid #e0e0e0;border-left:4px solid #e0e0e0;border-radius:8px;padding:.85rem 1rem;display:flex;flex-direction:column;gap:.5rem}.task-card--warning{border-left-color:#f59e0b}.task-card--limit{border-left-color:#ef4444;background:#fff8f8}.task-card__header{display:flex;align-items:baseline;gap:.5rem}.task-card__name{font-weight:600;flex:1}.task-card__elapsed{font-size:.875rem;color:#555;white-space:nowrap}.task-card--warning .task-card__elapsed{color:#d97706;font-weight:600}.task-card--limit .task-card__elapsed{color:#dc2626;font-weight:700}.task-card__overdue{font-size:.8rem;font-weight:700;color:#dc2626}.task-card__desc{margin:0;font-size:.85rem;color:#666}.task-card__tags{display:flex;flex-wrap:wrap;gap:.3rem}.tag{background:#e8ecff;color:#3a59e0;border-radius:4px;padding:.1rem .45rem;font-size:.75rem;font-weight:500}.task-card__actions{display:flex;gap:.5rem;flex-wrap:wrap}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0}@media(min-width:480px){.modal-backdrop{align-items:center;padding:1rem}}.modal{background:#fff;border-radius:12px 12px 0 0;width:100%;max-width:520px;max-height:90dvh;overflow-y:auto;box-shadow:0 8px 32px #0003}@media(min-width:480px){.modal{border-radius:12px}}.modal-header{display:flex;align-items:center;padding:1rem 1.25rem .75rem;border-bottom:1px solid #eee;position:sticky;top:0;background:#fff;z-index:1}.modal-title{margin:0;font-size:1.1rem;flex:1}.modal-close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:#888;padding:.25rem;line-height:1}.modal-body{padding:1.25rem}.task-form{display:flex;flex-direction:column;gap:.9rem}.form-field{display:flex;flex-direction:column;gap:.25rem}.form-field label{font-size:.875rem;font-weight:500}.label-hint{font-weight:400;color:#888;font-size:.8rem}.form-field input,.form-field textarea,.form-field select{padding:.5rem .75rem;border:1px solid #ccc;border-radius:6px;font-size:.95rem;font-family:inherit;width:100%}.form-field input:focus,.form-field textarea:focus{outline:2px solid #4f6ef7;border-color:transparent}.field-error{color:#d32f2f;font-size:.8rem}.form-actions{margin-top:.25rem}.history-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.history-item{border:1px solid #e0e0e0;border-radius:8px;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.35rem}.history-item__main{display:flex;align-items:baseline;gap:.75rem}.history-item__date{font-weight:600;font-size:.9rem}.history-item__user{color:#666;font-size:.8rem}.history-item__note{margin:0;font-size:.85rem;color:#444;font-style:italic}.saved-views{display:flex;flex-direction:column;gap:.5rem}.saved-views__list{display:flex;flex-wrap:wrap;gap:.4rem}.saved-view-chip{display:inline-flex;align-items:center;background:#e8ecff;border-radius:20px;overflow:hidden}.saved-view-chip__name{background:none;border:none;padding:.25rem .6rem;font-size:.8rem;color:#3a59e0;font-weight:500;cursor:pointer}.saved-view-chip__name:hover{text-decoration:underline}.saved-view-chip__del{background:none;border:none;padding:.2rem .5rem .2rem .1rem;font-size:.75rem;color:#888;cursor:pointer;line-height:1}.saved-view-chip__del:hover{color:#d32f2f}.saved-views__save-form{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.saved-views__name-input{padding:.35rem .65rem;border:1px solid #ccc;border-radius:6px;font-size:.85rem;flex:1;min-width:140px}.board-info p{margin:.4rem 0}.board-info__hint{color:#777;font-size:.875rem}.join-code{font-family:monospace;font-size:1.1rem;letter-spacing:.15em;background:#f0f4ff;padding:.15rem .5rem;border-radius:4px;-webkit-user-select:all;user-select:all}.nav-board-btn{background:none;border:1px solid #dde2ff;border-radius:20px;padding:.2rem .75rem;font-size:.85rem;font-weight:600;color:#3a59e0;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:40vw}.nav-board-btn:hover{background:#f0f4ff}.saved-view-chip--confirming{background:#fff0f0;border:1px solid #f5a0a0}.saved-view-chip__confirm-label{padding:.25rem .5rem;font-size:.8rem;color:#c00}.saved-view-chip__confirm-yes,.saved-view-chip__confirm-no{background:none;border:none;font-size:.8rem;font-weight:600;cursor:pointer;padding:.2rem .5rem}.saved-view-chip__confirm-yes{color:#c00}.saved-view-chip__confirm-yes:hover{text-decoration:underline}.saved-view-chip__confirm-no{color:#555}.saved-view-chip__confirm-no:hover{text-decoration:underline}.import-modal{display:flex;flex-direction:column;gap:.9rem}.import-textarea{width:100%;padding:.6rem .75rem;border:1px solid #ccc;border-radius:6px;font-family:monospace;font-size:.85rem;line-height:1.5;resize:vertical;min-height:180px}.import-textarea:focus{outline:2px solid #4f6ef7;border-color:transparent}.import-preview{display:flex;flex-direction:column;gap:.5rem}.import-errors{margin:0;padding:0 0 0 1.25rem;color:#d32f2f;font-size:.8rem;display:flex;flex-direction:column;gap:.2rem}.import-summary{margin:0;font-size:.875rem;color:#444}
