@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--text-primary:#0f172a;--text-secondary:#64748b;--accent-color:#3b82f6;--accent-hover:#2563eb;--border-color:#e2e8f0;--danger-color:#ef4444;--success-color:#10b981;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius-md:.5rem;--radius-lg:1rem}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit;transition:all .2s}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-content{width:100%;max-width:1920px;margin:0 auto;padding:2rem}.card{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:box-shadow .3s;overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.form-group{margin-bottom:1rem}.form-label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.input-field{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);outline:none;width:100%;padding:.75rem 1rem;font-size:.875rem;transition:all .2s}.input-field:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}.checkbox-group{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#f1f5f9;align-items:flex-start;gap:.5rem;margin-top:1rem;padding:.75rem;display:flex}.checkbox-group input{margin-top:.2rem}.btn{border-radius:var(--radius-md);justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;display:inline-flex}.btn-primary{background-color:var(--accent-color);color:#fff}.btn-primary:hover{background-color:var(--accent-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{border:1px solid var(--border-color);color:var(--text-secondary);background-color:#0000}.btn-secondary:hover{color:var(--text-primary);background-color:#f1f5f9}.dialog-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#0006;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.3s cubic-bezier(.16,1,.3,1) forwards fadeIn}.text-danger{color:var(--danger-color)}.text-success{color:var(--success-color)}.text-xs{font-size:.75rem}.dashboard-tabs{border-bottom:2px solid var(--border-color);flex-shrink:0;gap:0;margin-bottom:1.5rem;display:flex}.dashboard-tab{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s}.dashboard-tab:hover{color:var(--accent-color);background:#3b82f60a}.dashboard-tab.active{color:var(--accent-color);border-bottom-color:var(--accent-color)}.board-layout{flex:1;gap:1.5rem;min-height:0;display:flex;overflow:hidden}.board-tree-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-direction:column;width:280px;min-width:280px;display:flex;overflow:hidden}.board-tree-header{border-bottom:1px solid var(--border-color);background:var(--bg-primary);flex-shrink:0;padding:1rem 1.25rem;font-size:.9rem;font-weight:700}.board-tree-body{flex:1;padding:.5rem 0;overflow-y:auto}.board-content-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.board-content-header{border-bottom:1px solid var(--border-color);background:var(--bg-primary);flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;font-size:.9rem;font-weight:700;display:flex}.board-content-body{flex:1;position:relative;overflow-y:auto}.menu-tree-item{cursor:pointer;color:var(--text-primary);border-left:3px solid #0000;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;transition:all .15s;display:flex}.menu-tree-item:hover{background:#3b82f60f}.menu-tree-item.active{border-left-color:var(--accent-color);color:var(--accent-color);background:#3b82f614;font-weight:600}.menu-tree-item.level-1{padding-left:1rem}.menu-tree-item.level-2{padding-left:2rem}.menu-tree-item.level-3{padding-left:3rem}.menu-tree-toggle{width:18px;height:18px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;font-size:.65rem;transition:transform .2s;display:flex}.menu-tree-toggle.expanded{transform:rotate(90deg)}.menu-tree-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.menu-tree-id{color:var(--text-secondary);flex-shrink:0;font-family:monospace;font-size:.7rem}.menu-tree-leaf-badge{color:var(--success-color);background:#10b9811f;border-radius:3px;flex-shrink:0;padding:1px 4px;font-size:.6rem}.post-table{border-collapse:collapse;width:100%}.post-table thead{background:var(--bg-primary);z-index:5;position:sticky;top:0}.post-table th{color:var(--text-secondary);text-align:left;border-bottom:1px solid var(--border-color);white-space:nowrap;padding:.75rem 1rem;font-size:.8rem;font-weight:600}.post-table td{border-bottom:1px solid var(--border-color);white-space:nowrap;text-overflow:ellipsis;padding:.6rem 1rem;font-size:.85rem;overflow:hidden}.post-table .td-title{white-space:normal;cursor:pointer;max-width:300px;color:var(--accent-color);font-weight:500}.post-table .td-title:hover{text-underline-offset:2px;text-decoration:underline}.post-table tbody tr:hover{background:#3b82f60a}.post-detail{padding:1.5rem}.post-detail-header{border-bottom:1px solid var(--border-color);margin-bottom:1.5rem;padding-bottom:1rem}.post-detail-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1.3rem;font-weight:700}.post-detail-meta{color:var(--text-secondary);flex-wrap:wrap;gap:1.5rem;font-size:.8rem;display:flex}.post-detail-body{font-size:.95rem;line-height:1.8}.post-detail-body .content-block{margin-bottom:1rem}.post-detail-body .content-block img{border-radius:var(--radius-md);max-width:100%;box-shadow:var(--shadow-sm)}.post-detail-body .content-block video{border-radius:var(--radius-md);max-width:100%}.post-detail-body .content-block .link-preview{border:1px solid var(--border-color);border-radius:var(--radius-md);text-decoration:none;transition:box-shadow .2s;display:block;overflow:hidden}.post-detail-body .content-block .link-preview:hover{box-shadow:var(--shadow-md)}.post-detail-body .content-block .link-preview iframe{aspect-ratio:16/9;border:none;width:100%}.post-detail-actions{border-top:1px solid var(--border-color);gap:.75rem;margin-top:2rem;padding-top:1.5rem;display:flex}.post-detail-attachments{background:var(--bg-primary);border-radius:var(--radius-md);margin-top:1.5rem;padding:1rem}.post-detail-attachments h4{color:var(--text-secondary);margin-bottom:.75rem;font-size:.85rem;font-weight:600}.post-attachment-item{color:var(--accent-color);cursor:pointer;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.85rem;display:flex}.post-attachment-item:hover{text-decoration:underline}.post-editor{padding:1.5rem}.post-editor-row{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.post-editor-label{color:var(--text-secondary);white-space:nowrap;min-width:80px;font-size:.85rem;font-weight:600}.post-editor-input{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);outline:none;flex:1;min-width:200px;padding:.6rem .875rem;font-size:.875rem;transition:all .2s}.post-editor-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}.post-editor-toolbar{border:1px solid var(--border-color);border-radius:var(--radius-md) var(--radius-md) 0 0;background:var(--bg-primary);border-bottom:none;flex-wrap:wrap;gap:.25rem;padding:.5rem;display:flex}.post-editor-toolbar button{cursor:pointer;color:var(--text-primary);background:0 0;border:1px solid #0000;border-radius:4px;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.8rem;transition:all .15s;display:flex}.post-editor-toolbar button:hover{border-color:var(--border-color);background:#3b82f614}.post-editor-content{border:1px solid var(--border-color);border-radius:0 0 var(--radius-md) var(--radius-md);background:var(--bg-secondary);min-height:300px;padding:1rem;overflow-y:auto}.post-editor-block{border-radius:var(--radius-md);border:1px solid #0000;margin-bottom:.75rem;padding:.5rem;transition:border-color .2s;position:relative}.post-editor-block:hover{border-color:var(--border-color)}.post-editor-block textarea{resize:vertical;background:0 0;border:none;outline:none;width:100%;min-height:60px;font-family:inherit;font-size:.9rem;line-height:1.7}.post-editor-block img,.post-editor-block video{border-radius:var(--radius-md);max-width:100%}.post-editor-block-remove{color:#fff;cursor:pointer;background:#ef4444e6;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;display:none;position:absolute;top:4px;right:4px}.post-editor-block:hover .post-editor-block-remove{display:flex}.post-editor-actions{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.menu-dropdown{position:relative}.menu-dropdown-trigger{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;min-width:250px;padding:.6rem .875rem;font-size:.875rem;display:flex}.menu-dropdown-list{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;max-height:300px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.menu-dropdown-item{cursor:pointer;padding:.5rem 1rem;font-size:.85rem;transition:background .15s}.menu-dropdown-item:hover{background:#3b82f60f}.menu-dropdown-item.disabled{color:var(--text-secondary);opacity:.5;cursor:not-allowed}.menu-dropdown-item.level-1{padding-left:1rem;font-weight:600}.menu-dropdown-item.level-2{padding-left:2rem}.menu-dropdown-item.level-3{padding-left:3rem}.menu-manage-dialog{background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:800px;max-height:80vh;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.menu-manage-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.menu-manage-header h2{font-size:1.1rem;font-weight:700}.menu-manage-body{flex:1;min-height:0;display:flex}.menu-manage-tree{border-right:1px solid var(--border-color);width:320px;padding:.5rem 0;overflow-y:auto}.menu-manage-form{flex:1;padding:1.5rem;overflow-y:auto}.menu-manage-form-group{margin-bottom:1.25rem}.menu-manage-form-group label{color:var(--text-secondary);margin-bottom:.4rem;font-size:.8rem;font-weight:600;display:block}.menu-manage-form-group input[type=text]{border:1px solid var(--border-color);border-radius:var(--radius-md);outline:none;width:100%;padding:.6rem .875rem;font-size:.875rem}.menu-manage-form-group input[type=text]:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}.menu-manage-checkbox{align-items:center;gap:.5rem;padding:.5rem 0;display:flex}.menu-manage-checkbox input{width:1.1rem;height:1.1rem;accent-color:var(--accent-color)}.menu-manage-checkbox label{color:var(--text-primary);cursor:pointer;font-size:.85rem}.menu-manage-checkbox.disabled label{color:var(--text-secondary);opacity:.5}.menu-manage-actions{flex-wrap:wrap;gap:.5rem;margin-top:1.5rem;display:flex}.menu-manage-tree-item{cursor:pointer;border-left:3px solid #0000;align-items:center;gap:.35rem;padding:.5rem 1rem;font-size:.83rem;transition:all .15s;display:flex}.menu-manage-tree-item:hover{background:#3b82f60f}.menu-manage-tree-item.selected{border-left-color:var(--accent-color);background:#3b82f61a;font-weight:600}.menu-manage-tree-item.level-1{padding-left:1rem}.menu-manage-tree-item.level-2{padding-left:2.25rem}.menu-manage-tree-item.level-3{padding-left:3.5rem}.hover-bg:hover{background:var(--bg-primary)}.ql-font-malgun{font-family:Malgun Gothic,맑은 고딕,sans-serif}.ql-font-dotum{font-family:Dotum,돋움,sans-serif}.ql-font-batang{font-family:Batang,바탕,serif}.ql-font-nanum{font-family:Nanum Gothic,나눔고딕,sans-serif}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=malgun]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=malgun]:before{content:"맑은 고딕";font-family:Malgun Gothic,맑은 고딕,sans-serif}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=dotum]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=dotum]:before{content:"돋움";font-family:Dotum,돋움,sans-serif}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=batang]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=batang]:before{content:"바탕";font-family:Batang,바탕,serif}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=nanum]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=nanum]:before{content:"나눔고딕";font-family:Nanum Gothic,나눔고딕,sans-serif}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="10px"]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="10px"]:before{content:"10px"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="12px"]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="12px"]:before{content:"12px"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="14px"]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="14px"]:before{content:"14px"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="16px"]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="16px"]:before{content:"16px"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="18px"]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="18px"]:before{content:"18px"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="20px"]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="20px"]:before{content:"20px"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="24px"]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="24px"]:before{content:"24px"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="30px"]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="30px"]:before{content:"30px"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="36px"]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="36px"]:before{content:"36px"}.ql-editor img{max-width:100%}.ql-editor .ql-video-wrapper{display:block}.ql-container{box-sizing:border-box;height:100%;margin:0;font-family:Helvetica,Arial,sans-serif;font-size:13px;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container:not(.ql-disabled) li[data-list=checked]>.ql-ui,.ql-container:not(.ql-disabled) li[data-list=unchecked]>.ql-ui{cursor:pointer}.ql-clipboard{height:1px;position:absolute;top:50%;left:-100000px;overflow-y:hidden}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word;outline:none;height:100%;padding:12px 15px;line-height:1.42;overflow-y:auto}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0}@supports (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-set:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor table{border-collapse:collapse}.ql-editor td{border:1px solid #000;padding:2px 5px}.ql-editor ol{padding-left:1.5em}.ql-editor li{padding-left:1.5em;list-style-type:none;position:relative}.ql-editor li>.ql-ui:before{text-align:right;white-space:nowrap;width:1.2em;margin-left:-1.5em;margin-right:.3em;display:inline-block}.ql-editor li[data-list=checked]>.ql-ui,.ql-editor li[data-list=unchecked]>.ql-ui{color:#777}.ql-editor li[data-list=bullet]>.ql-ui:before{content:"•"}.ql-editor li[data-list=checked]>.ql-ui:before{content:"☑"}.ql-editor li[data-list=unchecked]>.ql-ui:before{content:"☐"}@supports (counter-set:none){.ql-editor li[data-list]{counter-set:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list]{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered]{counter-increment:list-0}.ql-editor li[data-list=ordered]>.ql-ui:before{content:counter(list-0, decimal) ". "}.ql-editor li[data-list=ordered].ql-indent-1{counter-increment:list-1}.ql-editor li[data-list=ordered].ql-indent-1>.ql-ui:before{content:counter(list-1, lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-set:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-2{counter-increment:list-2}.ql-editor li[data-list=ordered].ql-indent-2>.ql-ui:before{content:counter(list-2, lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-set:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-3{counter-increment:list-3}.ql-editor li[data-list=ordered].ql-indent-3>.ql-ui:before{content:counter(list-3, decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-set:list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-4{counter-increment:list-4}.ql-editor li[data-list=ordered].ql-indent-4>.ql-ui:before{content:counter(list-4, lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-set:list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-5{counter-increment:list-5}.ql-editor li[data-list=ordered].ql-indent-5>.ql-ui:before{content:counter(list-5, lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-set:list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-6{counter-increment:list-6}.ql-editor li[data-list=ordered].ql-indent-6>.ql-ui:before{content:counter(list-6, decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-set:list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-reset:list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-7{counter-increment:list-7}.ql-editor li[data-list=ordered].ql-indent-7>.ql-ui:before{content:counter(list-7, lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-set:list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-reset:list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-8{counter-increment:list-8}.ql-editor li[data-list=ordered].ql-indent-8>.ql-ui:before{content:counter(list-8, lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-set:list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-reset:list-9}}.ql-editor li[data-list=ordered].ql-indent-9{counter-increment:list-9}.ql-editor li[data-list=ordered].ql-indent-9>.ql-ui:before{content:counter(list-9, decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor li.ql-direction-rtl{padding-right:1.5em}.ql-editor li.ql-direction-rtl>.ql-ui:before{text-align:left;margin-left:.3em;margin-right:-1.5em}.ql-editor table{table-layout:fixed;width:100%}.ql-editor table td{outline:none}.ql-editor .ql-code-block-container{font-family:monospace}.ql-editor .ql-video{max-width:100%;display:block}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{text-align:inherit;direction:rtl}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor .ql-ui{position:absolute}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);pointer-events:none;font-style:italic;position:absolute;left:15px;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{cursor:pointer;float:left;background:0 0;border:none;width:28px;height:24px;padding:3px 5px;display:inline-block}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media (pointer:coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{vertical-align:middle;display:inline-block}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2px}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1px}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-top:5px;margin-bottom:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor .ql-code-block-container{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor .ql-code-block-container{margin-top:5px;margin-bottom:5px;padding:5px 10px}.ql-snow .ql-editor code{padding:2px 4px;font-size:85%}.ql-snow .ql-editor .ql-code-block-container{color:#f8f8f2;background-color:#23241f;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;float:left;vertical-align:middle;height:24px;font-size:14px;font-weight:500;display:inline-block;position:relative}.ql-snow .ql-picker-label{cursor:pointer;width:100%;height:100%;padding-left:8px;padding-right:2px;display:inline-block;position:relative}.ql-snow .ql-picker-label:before{line-height:22px;display:inline-block}.ql-snow .ql-picker-options{white-space:nowrap;background-color:#fff;min-width:100%;padding:4px 8px;display:none;position:absolute}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;padding-top:5px;padding-bottom:5px;display:block}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{z-index:1;margin-top:-1px;display:block;top:100%}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{width:24px;height:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{width:152px;padding:3px 5px}.ql-snow .ql-color-picker .ql-picker-item{float:left;border:1px solid #0000;width:16px;height:16px;margin:2px;padding:0}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{width:18px;margin-top:-9px;position:absolute;top:50%;right:0}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-code-block-container{position:relative}.ql-code-block-container .ql-ui{top:5px;right:5px}.ql-toolbar.ql-snow{box-sizing:border-box;border:1px solid #ccc;padding:8px;font-family:Helvetica Neue,Helvetica,Arial,sans-serif}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid #0000}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid #0000;box-shadow:0 2px 8px #0003}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{color:#444;white-space:nowrap;background-color:#fff;border:1px solid #ccc;padding:5px 12px;box-shadow:0 0 5px #ddd}.ql-snow .ql-tooltip:before{content:"Visit URL:";margin-right:8px;line-height:26px}.ql-snow .ql-tooltip input[type=text]{border:1px solid #ccc;width:170px;height:26px;margin:0;padding:3px 5px;font-size:13px;display:none}.ql-snow .ql-tooltip a.ql-preview{text-overflow:ellipsis;vertical-align:top;max-width:200px;display:inline-block;overflow-x:hidden}.ql-snow .ql-tooltip a.ql-action:after{content:"Edit";border-right:1px solid #ccc;margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{content:"Save";border-right:0;padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.mobile-shell{background:linear-gradient(135deg,#0f0c29 0%,#302b63 50%,#24243e 100%);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:1rem;font-family:Inter,-apple-system,sans-serif;display:flex}.mobile-container{aspect-ratio:9/16;color:#e2e8f0;background:linear-gradient(#1a1a2e 0%,#16213e 100%);border-radius:2rem;flex-direction:column;width:100%;max-width:430px;display:flex;position:relative;overflow:hidden;box-shadow:0 25px 60px #00000080,0 0 0 1px #ffffff14}.mobile-auth{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1.5rem;padding:2rem;display:flex}.mobile-auth-icon{background:#fff;border:4px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:90px;height:90px;margin-bottom:.5rem;display:flex;overflow:hidden;box-shadow:0 10px 30px #0003}@keyframes pulseGlow{0%,to{box-shadow:0 8px 32px #667eea59}50%{box-shadow:0 8px 48px #667eea8c}}.mobile-auth h1{color:#fff;letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.mobile-auth p{color:#94a3b8;font-size:.85rem;line-height:1.5}.mobile-auth-input{text-align:center;letter-spacing:.08em;color:#fff;background:#ffffff0f;border:1.5px solid #ffffff1f;border-radius:.875rem;outline:none;width:100%;max-width:280px;padding:.875rem 1.125rem;font-family:Inter,monospace;font-size:1.05rem;transition:all .3s}.mobile-auth-input:focus{background:#ffffff1a;border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.mobile-auth-input::placeholder{color:#64748b;letter-spacing:.05em}.mobile-auth-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.875rem;width:100%;max-width:280px;padding:.875rem;font-size:1rem;font-weight:600;transition:all .3s;box-shadow:0 4px 16px #667eea4d}.mobile-auth-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea73}.mobile-auth-btn:active{transform:translateY(0)}.mobile-auth-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.mobile-auth-error{color:#f87171;background:#f871711a;border-radius:.5rem;padding:.5rem 1rem;font-size:.8rem;animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.mobile-header{background:#ffffff0a;border-bottom:1px solid #ffffff0f;flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.mobile-header-user{align-items:center;gap:.625rem;display:flex}.mobile-header-avatar{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:flex}.mobile-header-info{flex-direction:column;display:flex}.mobile-header-name{color:#fff;font-size:.9rem;font-weight:600}.mobile-header-position{color:#94a3b8;font-size:.7rem}.mobile-header-logout{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #ffffff1f;border-radius:.5rem;padding:.375rem .75rem;font-size:.75rem;transition:all .2s}.mobile-header-logout:hover{color:#fff;background:#ffffff14}.mobile-menu{flex-direction:column;flex:1;padding:1.5rem;display:flex;overflow-y:auto}.mobile-menu-grid{grid-template-columns:repeat(2,1fr);gap:1rem;width:100%;display:grid}.mobile-menu-item{aspect-ratio:1;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:1.5rem;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.mobile-menu-item:hover{background:#667eea26;border-color:#667eea66;transform:translateY(-4px)}.mobile-menu-item:active{transform:scale(.95)}.mobile-menu-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:1rem;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.5rem;display:flex;box-shadow:0 4px 12px #667eea4d}.mobile-menu-label{color:#fff;font-size:.95rem;font-weight:600}.mobile-search{flex-shrink:0;padding:.75rem 1.25rem}.mobile-search-input{color:#fff;background:#ffffff0d;border:1.5px solid #ffffff14;border-radius:.75rem;outline:none;width:100%;padding:.75rem 1rem .75rem 2.5rem;font-size:.875rem;transition:all .3s}.mobile-search-input:focus{background:#ffffff14;border-color:#667eea}.mobile-search-input::placeholder{color:#64748b}.mobile-search-wrapper{position:relative}.mobile-search-icon{color:#64748b;pointer-events:none;position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.mobile-filter-row{align-items:flex-end;gap:.5rem;margin-top:.5rem;display:flex}.mobile-filter-group{flex:1;min-width:0}.mobile-filter-label{color:#94a3b8;margin-bottom:.25rem;font-size:.65rem;font-weight:500;display:block}.mobile-filter-select{color:#fff;cursor:pointer;appearance:none;background:#ffffff0d url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") right .5rem center no-repeat;border:1.5px solid #ffffff14;border-radius:.5rem;outline:none;width:100%;padding:.5rem 1.5rem .5rem .5rem;font-size:.8rem;transition:all .3s}.mobile-filter-select:focus{background-color:#ffffff14;border-color:#667eea}.mobile-filter-select option{color:#e2e8f0;background:#1a1a2e}.mobile-filter-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;flex-shrink:0;padding:.5rem .875rem;font-size:.8rem;font-weight:600;transition:all .25s}.mobile-filter-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.mobile-list{flex:1;padding:0 1.25rem 1rem;overflow-y:auto}.mobile-list::-webkit-scrollbar{width:4px}.mobile-list::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.mobile-member-card{cursor:pointer;background:#ffffff0a;border:1px solid #ffffff0f;border-radius:.875rem;align-items:center;gap:.875rem;margin-bottom:.5rem;padding:.875rem;transition:all .25s;display:flex}.mobile-member-card:hover{background:#ffffff14;border-color:#667eea4d;transform:translate(4px)}.mobile-member-card:active{transform:scale(.98)}.mobile-member-photo{object-fit:cover;border:2px solid #ffffff1a;border-radius:50%;flex-shrink:0;width:48px;height:48px}.mobile-member-photo-placeholder{color:#64748b;background:#ffffff14;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;display:flex}.mobile-member-info{flex:1;min-width:0}.mobile-member-name{color:#fff;margin-bottom:.125rem;font-size:.95rem;font-weight:600}.mobile-member-sub{color:#94a3b8;font-size:.75rem}.mobile-member-arrow{color:#475569;flex-shrink:0;transition:color .2s}.mobile-member-card:hover .mobile-member-arrow{color:#667eea}.mobile-detail{flex-direction:column;flex:1;animation:.3s slideIn;display:flex;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.mobile-detail-header{border-bottom:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.mobile-detail-back{color:#e2e8f0;cursor:pointer;background:#ffffff0f;border:none;border-radius:.5rem;justify-content:center;align-items:center;padding:.375rem;transition:all .2s;display:flex}.mobile-detail-back:hover{background:#ffffff1f}.mobile-detail-title{font-size:1.05rem;font-weight:600}.mobile-detail-body{flex:1;padding:1.5rem 1.25rem;overflow-y:auto}.mobile-detail-photo-section{justify-content:center;margin-bottom:1.5rem;display:flex}.mobile-detail-photo{object-fit:cover;border:3px solid #667eea4d;border-radius:50%;width:100px;height:100px;box-shadow:0 8px 32px #0000004d}.mobile-detail-photo-placeholder{color:#475569;background:#ffffff0f;border:3px solid #ffffff14;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;font-size:2.5rem;display:flex}.mobile-detail-name{text-align:center;color:#fff;margin-bottom:.25rem;font-size:1.375rem;font-weight:700}.mobile-detail-position-badge{text-align:center;color:#94a3b8;margin-bottom:1.5rem;font-size:.8rem}.mobile-detail-table{border-collapse:collapse;width:100%}.mobile-detail-table tr{border-bottom:1px solid #ffffff0f}.mobile-detail-table tr:last-child{border-bottom:none}.mobile-detail-table td{padding:.875rem 0;font-size:.875rem}.mobile-detail-table td:first-child{color:#94a3b8;width:30%;font-weight:500}.mobile-detail-table td:last-child{color:#e2e8f0;font-weight:500}.mobile-edit-input{color:#fff;background:#667eea14;border:1.5px solid #667eea66;border-radius:.5rem;outline:none;width:100%;padding:.625rem .75rem;font-family:inherit;font-size:.875rem;transition:all .25s}.mobile-edit-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.mobile-detail-actions{border-top:1px solid #ffffff0f;flex-shrink:0;padding:1rem 1.25rem}.mobile-edit-btn{cursor:pointer;border:none;border-radius:.875rem;width:100%;padding:.875rem;font-size:.95rem;font-weight:600;transition:all .25s}.mobile-edit-btn-primary{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 16px #667eea4d}.mobile-edit-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #667eea66}.mobile-edit-btn-secondary{color:#e2e8f0;background:#ffffff0f;border:1px solid #ffffff1f}.mobile-edit-btn-secondary:hover{background:#ffffff1a}.mobile-edit-btn-group{gap:.625rem;display:flex}.mobile-edit-btn-group .mobile-edit-btn{flex:1}.mobile-header-actions{align-items:center;gap:.5rem;display:flex}.mobile-settings-wrapper{position:relative}.mobile-settings-btn{cursor:pointer;background:0 0;border:1px solid #ffffff1f;border-radius:.5rem;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .2s;display:flex}.mobile-settings-btn:hover{background:#ffffff14}.mobile-settings-menu{z-index:50;background:#1e2a3a;border:1px solid #ffffff1f;border-radius:.75rem;min-width:160px;animation:.15s menuFadeIn;position:absolute;top:calc(100% + .375rem);right:0;overflow:hidden;box-shadow:0 8px 24px #0006}@keyframes menuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.mobile-settings-menu-item{color:#e2e8f0;text-align:left;cursor:pointer;white-space:nowrap;background:0 0;border:none;width:100%;padding:.75rem 1rem;font-size:.85rem;transition:background .15s;display:block}.mobile-settings-menu-item:hover{background:#ffffff14}.mobile-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.mobile-modal{background:linear-gradient(#1e2a3a 0%,#1a1a2e 100%);border:1px solid #ffffff1a;border-radius:1.25rem;width:100%;max-width:340px;padding:1.75rem;animation:.25s modalIn;box-shadow:0 20px 50px #00000080}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.mobile-modal-title{color:#fff;text-align:center;margin-bottom:.5rem;font-size:1.2rem;font-weight:700}.mobile-modal-desc{color:#94a3b8;text-align:center;white-space:pre-line;margin-bottom:1.25rem;font-size:.8rem;line-height:1.5}.mobile-modal-field{margin-bottom:.875rem}.mobile-modal-label{color:#94a3b8;margin-bottom:.375rem;font-size:.75rem;font-weight:600;display:block}.mobile-modal-input{color:#fff;box-sizing:border-box;background:#ffffff0f;border:1.5px solid #ffffff1f;border-radius:.625rem;outline:none;width:100%;padding:.75rem .875rem;font-size:.9rem;transition:all .25s}.mobile-modal-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.mobile-modal-input::placeholder{color:#64748b}.mobile-modal-error{color:#f87171;text-align:center;background:#f871711a;border-radius:.5rem;margin-bottom:.875rem;padding:.5rem .75rem;font-size:.78rem;animation:.4s shake}.mobile-modal-actions{flex-direction:column;gap:.5rem;margin-top:.5rem;display:flex}.mobile-modal-btn{cursor:pointer;border:none;border-radius:.75rem;width:100%;padding:.8rem;font-size:.9rem;font-weight:600;transition:all .25s}.mobile-modal-btn:disabled{opacity:.5;cursor:not-allowed}.mobile-modal-btn-primary{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 16px #667eea4d}.mobile-modal-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #667eea73}.mobile-modal-btn-secondary{color:#94a3b8;background:#ffffff0f;border:1px solid #ffffff1f}.mobile-modal-btn-secondary:hover{color:#fff;background:#ffffff1a}.mobile-count{color:#94a3b8;flex-shrink:0;padding:0 1.25rem .5rem;font-size:.75rem}.mobile-empty{color:#64748b;text-align:center;flex:1;justify-content:center;align-items:center;padding:2rem;font-size:.875rem;display:flex}.mobile-toast{color:#fff;z-index:100;background:#10b981e6;border-radius:1rem;padding:.625rem 1.25rem;font-size:.825rem;font-weight:600;animation:.3s toastIn,.3s 1.7s forwards toastOut;position:absolute;bottom:5rem;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0000004d}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastOut{to{opacity:0;transform:translate(-50%)translateY(-10px)}}@media (height<=700px){.mobile-container{aspect-ratio:auto;border-radius:0;min-height:100vh}}@media (width<=430px){.mobile-shell{padding:0}.mobile-container{aspect-ratio:auto;border-radius:0;max-width:100%;min-height:100vh}}.attendance-calendar{width:100%;margin-bottom:1rem}.attendance-year-selector{justify-content:center;align-items:center;gap:1rem;margin-bottom:1rem;padding:.5rem 0;display:flex}.attendance-year-btn{color:#e2e8f0;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.attendance-year-btn:hover{background:#667eea33;border-color:#667eea66}.attendance-year-label{color:#fff;text-align:center;min-width:140px;font-size:1.15rem;font-weight:700}.attendance-grid-wrapper{-webkit-overflow-scrolling:touch;border:1px solid #ffffff0f;border-radius:.75rem;overflow-x:auto}.attendance-grid{border-collapse:collapse;table-layout:fixed;width:100%;font-size:.75rem}.attendance-grid th,.attendance-grid td{text-align:center;border:1px solid #ffffff0f;padding:.5rem .25rem}.attendance-grid-header-month{color:#94a3b8;background:#667eea26;width:40px;font-size:.85rem;font-weight:600}.attendance-grid-header{color:#94a3b8;background:#667eea1a;font-size:.85rem;font-weight:600}.attendance-grid-month{color:#94a3b8;background:#667eea14;font-size:.9rem;font-weight:600}.attendance-grid-cell{cursor:pointer;min-width:32px;height:32px;transition:all .2s;position:relative}.attendance-grid-cell.has-date:hover{background:#667eea26}.attendance-grid-cell.no-date{cursor:default;background:#00000026}.attendance-grid-cell.today-cell{background:#667eea26;animation:2.5s ease-in-out infinite pulseSlowFade}.attendance-check-icon{color:#22c55e;text-shadow:0 0 8px #22c55e80;font-size:1rem;font-weight:900}.attendance-count-badge{font-size:1rem;font-weight:700}.attendance-count-zero{color:#64748b}.attendance-count-full{color:#22c55e!important}.attendance-count-partial{color:#f59e0b!important}.attendance-pulse-active{animation:2s ease-in-out infinite attendanceSoftPulse}@keyframes attendanceSoftPulse{0%,to{opacity:1;filter:brightness()}50%{opacity:.5;filter:brightness(1.5)}}.attendance-notice{text-align:center;color:#94a3b8;background:#ffffff08;border-radius:.5rem;margin-top:.75rem;padding:.75rem 1rem;font-size:.78rem}.attendance-popup{background:linear-gradient(#1e2a3a 0%,#1a1a2e 100%);border:1px solid #ffffff1a;border-radius:1.25rem;width:90%;max-width:340px;padding:1.5rem;animation:.25s modalIn;box-shadow:0 20px 50px #00000080}.attendance-popup-large{max-width:380px}.attendance-popup-title{color:#fff;text-align:center;margin-bottom:.5rem;font-size:1.05rem;font-weight:700}.attendance-popup-subtitle{text-align:center;color:#94a3b8;margin-bottom:1rem;font-size:.85rem;font-weight:600}.attendance-popup-body{margin-bottom:1rem}.attendance-popup-check-row{justify-content:center;align-items:center;padding:1rem 0;display:flex}.attendance-popup-checkbox-label{cursor:pointer;color:#e2e8f0;align-items:center;gap:.75rem;font-size:.95rem;display:flex}.attendance-popup-checkbox-label.disabled{opacity:.4;cursor:not-allowed}.attendance-popup-checkbox{accent-color:#22c55e;cursor:pointer;width:1.5rem;height:1.5rem}.attendance-popup-check-text{font-weight:600}.attendance-popup-close{color:#94a3b8;cursor:pointer;background:#ffffff0f;border:none;border-radius:.75rem;width:100%;padding:.75rem;font-size:.9rem;font-weight:600;transition:all .2s}.attendance-popup-close:hover{color:#fff;background:#ffffff1a}.attendance-zone-info{text-align:center;background:#ffffff0a;border:1px solid #ffffff14;border-radius:.875rem;margin-bottom:1rem;padding:1rem}.attendance-zone-title{color:#fff;margin-bottom:.375rem;font-size:1.2rem;font-weight:700}.attendance-zone-staff{color:#94a3b8;flex-flow:wrap;justify-content:center;gap:.75rem;margin-bottom:.375rem;font-size:.85rem;display:flex}.attendance-zone-leader,.attendance-zone-teacher{font-weight:500}.attendance-zone-count{color:#667eea;font-size:.78rem;font-weight:600}.attendance-member-row{border-bottom:1px solid #ffffff0f;align-items:center;gap:.75rem;padding:.625rem 0;display:flex}.attendance-member-row:last-child{border-bottom:none}.attendance-member-photo{cursor:pointer;flex-shrink:0}.attendance-member-img{object-fit:cover;border:2px solid #ffffff1a;border-radius:50%;width:40px;height:40px}.attendance-member-img-placeholder{color:#64748b;background:#ffffff0f;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;display:flex}.attendance-member-info{cursor:pointer;flex:1;min-width:0}.attendance-member-name{color:#fff;font-size:.9rem;font-weight:600;display:block}.attendance-member-name.clickable{color:#667eea;text-underline-offset:2px;text-decoration:underline}.attendance-member-position{color:#94a3b8;font-size:.75rem;display:block}.attendance-member-check{flex-shrink:0}.attendance-member-checkbox{accent-color:#22c55e;cursor:pointer;width:1.25rem;height:1.25rem}.attendance-member-status{flex-shrink:0}.attendance-status-present{color:#22c55e;background:#22c55e26;border-radius:.375rem;padding:.2rem .5rem;font-size:.75rem;font-weight:700;display:inline-block}.attendance-status-absent{color:#ef4444;background:#ef44441a;border-radius:.375rem;padding:.2rem .5rem;font-size:.75rem;font-weight:700;display:inline-block}.attendance-zone-cards{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.attendance-zone-card{text-align:center;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:.875rem;padding:.875rem;transition:all .25s}.attendance-zone-card:hover{background:#667eea1a;border-color:#667eea4d;transform:translateY(-2px)}.attendance-zone-card-title{color:#e2e8f0;margin-bottom:.375rem;font-size:.85rem;font-weight:700}.attendance-zone-card-count{justify-content:center;align-items:baseline;gap:.25rem;display:flex}.attendance-zone-card-number{color:#667eea;font-size:1.3rem;font-weight:800}.attendance-zone-card-total{color:#94a3b8;font-size:.75rem}@keyframes pulseSlowFade{0%,to{opacity:1;text-shadow:0 0 5px #fbbf2480}50%{opacity:.4;text-shadow:none}}.animate-pulse-slow{color:#fbbf24;font-weight:700;animation:2.5s ease-in-out infinite pulseSlowFade}@keyframes pulseSlowFadeGreen{0%,to{opacity:1;text-shadow:0 0 5px #22c55e80}50%{opacity:.4;text-shadow:none}}.animate-pulse-green{color:#22c55e;font-weight:700;animation:2.5s ease-in-out infinite pulseSlowFadeGreen}@keyframes pulseSlowFadeSkyBlue{0%,to{opacity:1;text-shadow:0 0 5px #38bdf880}50%{opacity:.4;text-shadow:none}}.animate-pulse-skyblue{color:#38bdf8;font-weight:700;animation:2.5s ease-in-out infinite pulseSlowFadeSkyBlue}@keyframes pulseSlowFadePink{0%,to{opacity:1;text-shadow:0 0 5px #f472b680}50%{opacity:.4;text-shadow:none}}.animate-pulse-pink{color:#f472b6;font-weight:700;animation:2.5s ease-in-out infinite pulseSlowFadePink}@keyframes phoneColorShift{0%,to{background-color:#fde04759;box-shadow:0 0 10px #fde04799}50%{background-color:#ffffff73;box-shadow:0 0 15px #fffc}}.animate-phone-icon{border-radius:.5rem;align-items:center;padding:.3rem .4rem;font-size:1.1rem;text-decoration:none;animation:4s ease-in-out infinite phoneColorShift;display:flex}@keyframes iconYellowPulse{0%,to{opacity:1;filter:drop-shadow(0 0 6px #fde047cc);color:#fde047}50%{opacity:.4;filter:none;color:#fef08a}}.animate-icon-yellow-pulse{animation:2.5s ease-in-out infinite iconYellowPulse}@media (width<=500px),(height<=850px){.mobile-shell{padding:0}.mobile-container{aspect-ratio:auto;max-width:100%;height:100dvh;max-height:100vh;box-shadow:none;border-radius:0}}
