*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{max-width:1200px;margin:0 auto;padding:20px}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;box-shadow:0 2px 10px #0000001a}.navbar-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.navbar h1{font-size:1.5rem;font-weight:700}.navbar-links{display:flex;gap:1.5rem;align-items:center}.navbar-links a,.navbar-links button{color:#fff;text-decoration:none;font-weight:500;background:none;border:none;cursor:pointer;padding:.5rem 1rem;border-radius:4px;transition:background-color .2s}.navbar-links a:hover,.navbar-links button:hover{background-color:#ffffff1a}.card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;margin-bottom:1.5rem}.card h2{margin-bottom:1rem;color:#333}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover{background:#e5e7eb}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.problem-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:all .2s}.problem-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #0000001f}.problem-card h3{margin-bottom:.75rem;color:#1f2937}.problem-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.badge{padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600}.badge-category{background:#dbeafe;color:#1e40af}.badge-subject{background:#fce7f3;color:#9f1239}.badge-year{background:#d1fae5;color:#065f46}.badge-difficulty{background:#fed7aa;color:#9a3412}.chart-container{position:relative;height:300px;margin:2rem 0}.loading{display:flex;justify-content:center;align-items:center;min-height:200px}.spinner{border:4px solid #f3f4f6;border-top:4px solid #667eea;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{background:#fee2e2;color:#991b1b;padding:1rem;border-radius:8px;margin-bottom:1rem}.success-message{background:#d1fae5;color:#065f46;padding:1rem;border-radius:8px;margin-bottom:1rem}.search-bar{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.search-bar input,.search-bar select{flex:1;min-width:200px}@media (max-width: 768px){.navbar-content{flex-direction:column;gap:1rem}.navbar-links{flex-direction:column;width:100%}.grid-2,.grid-3{grid-template-columns:1fr}}.analysis-card{transition:all .2s}.analysis-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.btn-icon-delete{background:none;border:none;cursor:pointer;font-size:1.1rem;padding:.25rem .5rem;border-radius:6px;transition:background-color .2s;opacity:.6}.btn-icon-delete:hover{background-color:#fee2e2;opacity:1}.share-link-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#f9fafb;border-radius:8px;margin-bottom:.5rem}.share-link-url{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.8rem;color:#4b5563;word-break:break-all;background:#e5e7eb;padding:.35rem .75rem;border-radius:4px}.shared-banner{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.75rem 2rem;font-weight:500;font-size:.9rem}.shared-badge{display:inline-block;padding:.2rem .75rem;background:#fff3;border-radius:20px;font-size:.8rem;font-weight:600}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}@media (max-width: 768px){.share-link-item{flex-direction:column;align-items:stretch}}.filing-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.filing-mode-switch{display:flex;border:2px solid #e5e7eb;border-radius:8px;overflow:hidden}.filing-mode-btn{padding:.4rem 1rem;border:none;background:#fff;cursor:pointer;font-size:.85rem;font-weight:600;color:#6b7280;transition:all .2s}.filing-mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.filing-mode-btn:not(.active):hover{background:#f3f4f6}.items-tree{display:flex;flex-direction:column;gap:.75rem}.item-card{border:2px solid #e5e7eb;border-radius:10px;padding:1rem;transition:border-color .2s,box-shadow .2s}.item-card:hover{border-color:#c7d2fe}.item-major{background:#fff;border-left:4px solid #667eea}.item-sub{background:#f8fafc;border-left:4px solid #a5b4fc;margin-left:0}.item-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.item-number-badge{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;height:2rem;padding:0 .5rem;background:#667eea;color:#fff;border-radius:6px;font-weight:700;font-size:.9rem;flex-shrink:0}.item-title-area{flex:1;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;min-width:0}.item-title{font-weight:600;color:#1f2937;font-size:.95rem}.item-difficulty{font-size:.8rem;color:#f59e0b;white-space:nowrap}.item-actions{display:flex;gap:.25rem;flex-shrink:0}.btn-icon{background:none;border:none;cursor:pointer;padding:.3rem .45rem;border-radius:6px;font-size:1rem;transition:background-color .2s;opacity:.55}.btn-icon:hover{background:#f3f4f6;opacity:1}.item-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.item-tag{display:inline-block;padding:.15rem .6rem;border-radius:20px;font-size:.75rem;font-weight:600;border:1.5px solid;white-space:nowrap}.item-summary,.item-notes{margin-top:.5rem;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;line-height:1.6;white-space:pre-wrap}.item-summary{background:#f0f9ff;color:#0369a1;border-left:3px solid #38bdf8}.item-notes{background:#fefce8;color:#854d0e;border-left:3px solid #facc15}.item-children{margin-top:.75rem;padding-left:1.25rem;display:flex;flex-direction:column;gap:.5rem}.btn-add-sub{margin-top:.5rem;margin-left:1.25rem;padding:.35rem .75rem;background:transparent;border:1.5px dashed #a5b4fc;border-radius:6px;color:#667eea;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-add-sub:hover{background:#eef2ff;border-color:#667eea}.item-form{background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;padding:1rem}.item-form .form-group{margin-bottom:.75rem}.item-form .form-group label{font-size:.8rem;margin-bottom:.25rem}.item-form-row{display:flex;gap:.75rem;flex-wrap:wrap}.tag-list-display{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tag-picker{margin-top:.5rem;padding:.75rem;background:#f3f4f6;border-radius:8px}.tag-picker-list{display:flex;flex-wrap:wrap;gap:.35rem}.tag-picker-btn{padding:.2rem .65rem;border-radius:20px;font-size:.75rem;font-weight:600;border:1.5px solid;cursor:pointer;transition:all .15s}.tag-picker-btn:hover{transform:scale(1.05)}.tag-picker-btn.active{box-shadow:0 2px 8px #00000026}.tag-manager{margin-top:1rem;padding:1rem;background:#f9fafb;border-radius:10px;border:1px solid #e5e7eb}.tag-create-row{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-bottom:1rem}.tag-color-picker{display:flex;gap:.3rem;align-items:center}.tag-color-dot{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .15s;padding:0}.tag-color-dot:hover{transform:scale(1.2)}.tag-color-dot.active{border-color:#1f2937;box-shadow:0 0 0 2px #fff,0 0 0 4px #1f2937}.tag-manager-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag-manager-item{display:flex;align-items:center;gap:.25rem}.stats-tabs{display:flex;gap:0;margin-bottom:1.5rem;border:2px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#fff}.stats-tab{flex:1;padding:.75rem 1rem;border:none;background:#fff;cursor:pointer;font-size:.95rem;font-weight:600;color:#6b7280;transition:all .2s;text-align:center}.stats-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stats-tab:not(.active):hover{background:#f3f4f6}@media (max-width: 768px){.filing-header,.item-header{flex-direction:column;align-items:flex-start}.item-actions{align-self:flex-end}.item-form-row{flex-direction:column}.item-form-row .form-group{flex:1 1 100%!important}.tag-create-row{flex-direction:column;align-items:stretch}.item-children{padding-left:.75rem}.stats-tabs{flex-direction:column}}.problem-card-actions{position:absolute;top:1rem;right:1rem;display:flex;gap:.15rem;opacity:0;transition:opacity .2s}.problem-card:hover .problem-card-actions{opacity:1}.problem-card-actions .btn-icon,.problem-card-actions .btn-icon-delete{font-size:1rem;padding:.3rem .4rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h3{font-size:1.15rem;color:#1f2937}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#9ca3af;padding:.25rem .5rem;border-radius:6px;transition:all .15s;line-height:1}.modal-close:hover{background:#f3f4f6;color:#374151}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-body .form-group{margin-bottom:1.25rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.75rem}.guide-card{margin-top:2rem;background:#f9fafb}.guide-card h3{font-size:1.15rem;margin-bottom:1.25rem;color:#1f2937}.guide-section{margin-bottom:1.5rem}.guide-section h4{font-size:.95rem;font-weight:700;color:#374151;margin-bottom:.5rem}.guide-section ul,.guide-section ol{padding-left:1.5rem;line-height:2;color:#4b5563;font-size:.9rem}.guide-section ol{list-style:decimal}.guide-section li strong{color:#1f2937}.guide-caution{background:#fef3c7;padding:1rem;border-radius:8px;border-left:4px solid #f59e0b}.guide-caution h4,.guide-caution ul{color:#92400e}.form-hint{font-size:.8rem;color:#9ca3af;margin-top:.3rem}@media (max-width: 768px){.modal-content{max-height:95vh;border-radius:12px}.modal-body{padding:1rem}.modal-footer{flex-direction:column}.modal-footer .btn{width:100%;text-align:center}.problem-card-actions{opacity:1}}.problem-detail-header{border-left:4px solid #667eea}.problem-detail-analyses{display:flex;flex-direction:column;gap:.5rem}.analysis-link-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;transition:all .2s;cursor:pointer}.analysis-link-card:hover{border-color:#c7d2fe;background:#f0f4ff;transform:translate(4px)}.analysis-link-card h4{font-size:.95rem;word-break:break-word}.breadcrumb{display:flex;gap:.5rem;align-items:center;margin-bottom:1rem;font-size:.9rem}.breadcrumb a{color:#667eea;text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.breadcrumb span{color:#9ca3af}
