:root{--dg-gradient:linear-gradient(135deg,#0b3d2e,#145c43);--dg-gradient-hover:linear-gradient(135deg,#145c43,#1f7a5a)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;background-image:url(/static/media/DeltaNexusBackground.fe1b9519dba15482adbb.png);background-position:50%;background-repeat:no-repeat;background-size:cover;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}body:before{background:#0000008c;content:"";inset:0;pointer-events:none;position:fixed;z-index:-1}.header{background:linear-gradient(135deg,#0b3d2e,#145c43);border-bottom:1px solid #1f7a5a;box-shadow:0 4px 10px #00000059;color:#e6f5ef;padding:10px 20px;position:relative}.header,.header-text{align-items:center;display:flex;justify-content:center}.header-text{flex-direction:column;text-align:center}.logo{height:100px;left:20px;position:absolute}.header h1{font-family:Special Elite,monospace;font-size:2.6rem;letter-spacing:2px;line-height:1.1;margin:10px 0 0;text-shadow:0 1px 0 #0006,0 0 1px #0006;text-transform:uppercase}.subtext{font-family:Cormorant Garamond,serif;font-size:1.15rem;font-style:italic;letter-spacing:.6px;margin-bottom:0;margin-top:6px;opacity:.85}.nav-bar{background:linear-gradient(135deg,#0b3d2e,#145c43);border-bottom:1px solid #1f7a5a;display:flex;gap:12px;justify-content:center;padding:12px 0}.nav-item{background:linear-gradient(135deg,#145c43,#1f7a5a);border:1px solid #1f7a5a;border-radius:6px;box-shadow:0 3px 8px #0000004d;color:#e6f5ef;cursor:pointer;font-weight:600;padding:10px 22px;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease}.nav-item a{color:inherit;display:block;height:100%;text-decoration:none;width:100%}.nav-item:hover{background:linear-gradient(135deg,#1f7a5a,#2a8f6a);box-shadow:0 6px 14px #0006;transform:translateY(-2px)}.main-content{background-color:#fff;border-radius:10px;box-shadow:0 4px 6px #0000001a;margin:40px auto;max-width:50%;padding:20px;text-align:center}.main-content-wide{background:#0000;box-shadow:none;max-width:80%;padding:0}.main-content p{font-size:1rem;line-height:1.6}.auth-dropdown-container{position:absolute;right:20px;top:50%;transform:translateY(-50%)}.auth-toggle-button{background:linear-gradient(135deg,#0b3d2e,#145c43);background:var(--dg-gradient);border:1px solid #1f7a5a;border-radius:6px;box-shadow:0 3px 8px #0000004d;color:#e6f5ef;cursor:pointer;font-size:.95rem;font-weight:600;padding:8px 16px;transition:transform .15s ease,box-shadow .15s ease}.auth-toggle-button:hover{background:linear-gradient(135deg,#145c43,#1f7a5a);background:var(--dg-gradient-hover);transform:translateY(-1px)}.auth-dropdown-menu{background-color:#fff;border-radius:6px;box-shadow:0 4px 10px #00000026;color:#333;margin-top:8px;min-width:140px;padding:8px 0;position:absolute;right:0;z-index:1000}.auth-dropdown-menu button{background:none;border:none;cursor:pointer;display:block;font-size:.9rem;padding:8px 16px;text-align:left;width:100%}.auth-dropdown-menu button:hover{background-color:#f0f0f0}.App{font-family:Special Elite,monospace;text-align:center;text-shadow:0 1px 0 #0006,0 0 1px #0006}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.add-button{align-items:center;background:var(--dg-gradient);border:1px solid #1f7a5a;border-radius:50%;box-shadow:0 4px 10px #00000059;color:#e6f5ef;display:inline-flex;font-size:28px;height:52px;justify-content:center;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease;width:52px}.add-button:hover{background:var(--dg-gradient-hover);box-shadow:0 6px 16px #00000073;transform:translateY(-2px)}.skills-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.skill{background:#f9f9f9;border:1px solid #ccc;border-radius:5px;color:#333;font-family:Roboto,sans-serif;font-size:16px;padding:5px}.skill strong{color:#000}.sub-skills{color:#555;font-size:14px;margin-top:5px;padding-left:10px}.sub-skill{margin-bottom:3px}.step-container{animation:fadeStep .25s ease-in-out}.character-creation-input{font-family:Roboto,sans-serif;font-size:.8rem}.wizard-nav{align-items:center;display:flex;justify-content:space-between;margin-top:30px}.wizard-nav-left,.wizard-nav-right{display:flex;gap:12px}.nav-button{border:none;border-radius:6px;cursor:pointer;font-size:18px;font-weight:600;padding:10px 20px}.back-button{background-color:#555;color:#fff}.back-button:hover{background-color:#333}.next-button,.submit-button{background:var(--dg-gradient);border:1px solid #1f7a5a;border-radius:6px;box-shadow:0 3px 8px #0000004d;color:#e6f5ef;cursor:pointer;font-size:18px;font-weight:600;padding:10px 20px;transition:transform .15s ease,box-shadow .15s ease}.next-button:hover,.submit-button:hover{background:var(--dg-gradient-hover);box-shadow:0 6px 14px #0006;transform:translateY(-2px)}.submit-button{background-color:#2e7d32;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:18px;font-weight:600;padding:10px 20px}.submit-button:hover{background-color:#256a2b}.auth-form{margin:0 auto;max-width:400px;text-align:left}.page-fade{animation:fadeStep .25s ease-in-out}@keyframes fadeStep{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.character-page{width:100%}.choice{margin-top:18.72px}.character-shell{margin:0 auto;width:min(1200px,95%)}.character-header{margin-bottom:18px}.character-identity{align-items:stretch;display:flex;gap:18px;justify-content:space-between;margin-bottom:14px}.character-badge{background:linear-gradient(135deg,#0f3b2c,#1f7a5a);border:1px solid #e6f5ef1f;border-radius:12px;box-shadow:0 8px 24px #00000059;flex:1 1;padding:14px}.character-badge-inner{grid-gap:6px;display:grid;gap:6px;text-align:left}.character-badge-label{color:#e6f5efbf;font-size:.78rem;font-weight:800;letter-spacing:.14em}.character-badge-name{color:#e6f5ef;font-size:1.8rem;font-weight:900}.character-badge-profession{color:#e6f5efd9;font-size:1rem;font-weight:700}.character-header-right{grid-gap:10px;display:grid;gap:10px;width:320px}.character-meta{background:#0f1915a6;border:1px solid #e6f5ef1f;border-radius:12px;box-shadow:0 8px 24px #00000040;padding:12px 14px}.meta-row{border-bottom:1px solid #e6f5ef14;display:flex;gap:12px;justify-content:space-between;padding:6px 0}.meta-row:last-child{border-bottom:none}.meta-label{color:#e6f5efb3;font-size:.9rem;font-weight:600}.meta-value{color:#e6f5ef;font-size:.95rem;font-weight:800}.character-actions{display:flex;gap:10px;justify-content:flex-end}.character-action-button{background:linear-gradient(135deg,#145c43,#1f7a5a);border:1px solid #e6f5ef26;border-radius:10px;box-shadow:0 6px 16px #00000040;font-weight:800;transition:transform .15s ease,box-shadow .15s ease}.character-action-button:hover{box-shadow:0 10px 24px #00000059;transform:translateY(-1px)}.character-tabs{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.character-tab{background:#0f19158c;border:1px solid #e6f5ef24;border-radius:10px;color:#e6f5efd9;cursor:pointer;font-weight:800;padding:10px 14px;transition:transform .12s ease,background .12s ease,box-shadow .12s ease}.character-tab:hover{background:#145c4399;box-shadow:0 8px 18px #00000040;transform:translateY(-1px)}.character-tab.active{background:linear-gradient(135deg,#145c43,#1f7a5a);border:1px solid #e6f5ef33;color:#e6f5ef}.character-main-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,1fr)}.character-split-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1.2fr .8fr}.character-card{background:#ffffffeb;border:1px solid #00000014;border-radius:12px;box-shadow:0 6px 18px #0000002e;padding:14px;text-align:left}.card-title{color:#e6f5ef;font-size:1.05rem;font-weight:900;letter-spacing:.02em;margin-bottom:12px}.derived-key,.meta-label,.selection-title,.stat-key,.subskills-title,.summary-key{color:#e6f5efd9}.muted{color:#0009;font-weight:600}.stats-grid{grid-gap:10px;gap:10px}.stat-box{background:linear-gradient(135deg,#145c431a,#1f7a5a14);border:1px solid #145c432e;border-radius:10px;padding:10px}.stat-key{color:#145c43;font-size:.85rem;font-weight:900;letter-spacing:.06em}.stat-value{color:#0f3b2c;font-size:1.4rem;font-weight:900;margin-top:6px}.derived-grid{grid-gap:8px;display:grid;gap:8px}.derived-row{background:#0f19150f;border:1px solid #0000000f;border-radius:10px;display:flex;gap:12px;justify-content:space-between;padding:10px}.derived-key{color:#145c43;font-weight:900;letter-spacing:.06em}.derived-value{color:#0f3b2c;font-weight:900}.summary-list{grid-gap:10px;display:grid;gap:10px}.summary-row{background:#0f19150f;border:1px solid #0000000f;border-radius:10px;display:flex;gap:14px;justify-content:space-between;padding:10px}.summary-key{color:#000000a6;font-weight:800}.summary-value{color:#0f3b2c;font-weight:900}.skills-table{grid-gap:8px;display:grid;gap:8px}.skills-table-head{background:linear-gradient(135deg,#145c43,#1f7a5a);font-weight:900}.skills-table-head,.skills-table-row{grid-gap:10px;border-radius:10px;color:#e6f5ef;display:grid;gap:10px;grid-template-columns:1fr 110px;padding:10px}.skills-table-row{background:#0f19150f;border:1px solid #0000000f}.skills-skill{color:#cfcfcf;font-weight:800}.skills-value{color:#cfcfcf;font-weight:900;text-align:right}.subskills-list{grid-gap:12px;display:grid;gap:12px}.subskills-container{background:#0f19150d;border:1px solid #00000026;border-radius:12px;padding:10px}.subskills-title{color:#cfcfcf;font-weight:900;margin-bottom:8px}.subskills-items{grid-gap:8px;display:grid;gap:8px}.subskills-item{grid-gap:10px;border:1px solid #00000026;border-radius:10px;color:#cfcfcf;display:grid;gap:10px;grid-template-columns:1fr auto auto;padding:8px 10px}.subskills-name{color:#cfcfcf;font-weight:800}.subskills-val{color:#cfcfcf;font-weight:900}.subskills-tag{background:#1f7a5a26;border:1px solid #145c4338;border-radius:999px;color:#145c43;font-size:.72rem;font-weight:900;letter-spacing:.08em;padding:4px 8px}.bond-list{grid-gap:10px;display:grid;gap:10px}.bond-row{grid-gap:12px;background:#0f19150f;border:1px solid #0000000f;border-radius:10px;display:grid;gap:12px;grid-template-columns:34px 1fr;padding:10px}.bond-index{align-items:center;background:linear-gradient(135deg,#145c43,#1f7a5a);border-radius:8px;color:#e6f5ef;display:inline-flex;font-weight:900;justify-content:center}.bond-text{color:#cfcfcf;font-weight:800}.selections-list{grid-gap:12px;display:grid;gap:12px}.selection-block{background:#0f19150d;border:1px solid #0000000f;border-radius:12px;padding:10px}.selection-title{color:#145c43;font-weight:900;margin-bottom:8px}.selection-items{grid-gap:8px;display:grid;gap:8px}.selection-item{grid-gap:10px;background:#fffc;border:1px solid #0000000d;border-radius:10px;display:grid;gap:10px;grid-template-columns:1fr auto auto;padding:8px 10px}.selection-skill{color:#123a2b;font-weight:800}.selection-value{color:#0f3b2c;font-weight:900}.selection-tag{background:#1f7a5a26;border:1px solid #145c4338;border-radius:999px;color:#145c43;font-size:.72rem;font-weight:900;letter-spacing:.08em;padding:4px 8px}.raw-json{background:#0f19150f;border:1px solid #0000000f;border-radius:10px;font-size:.85rem;margin:0;padding:12px;white-space:pre-wrap;word-break:break-word}.skeleton{animation:skeletonMove 1.2s ease-in-out infinite;background:linear-gradient(90deg,#0000000d,#0000001f,#0000000d);background-size:200% 100%;min-height:220px}@keyframes skeletonMove{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width:950px){.character-identity{flex-direction:column}.character-header-right{width:100%}.character-main-grid,.character-split-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.campaign-page-shell{width:100%}.campaign-page-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.campaign-page-actions{display:flex;flex-wrap:wrap;gap:12px}.campaign-create-file-box button,.campaign-editor-actions button,.create-campaign-button,.delete-campaign-button,.file-editor button,.join-campaign-button,.modal-buttons button{background:var(--dg-gradient);border:1px solid #1f7a5a;border-radius:8px;box-shadow:0 4px 10px #00000040;color:#e6f5ef;cursor:pointer;font-weight:600;padding:10px 16px;transition:transform .15s ease,box-shadow .15s ease}.campaign-create-file-box button:hover,.campaign-editor-actions button:hover,.create-campaign-button:hover,.delete-campaign-button:hover,.file-editor button:hover,.join-campaign-button:hover,.modal-buttons button:hover{background:var(--dg-gradient-hover);box-shadow:0 6px 14px #00000059;transform:translateY(-2px)}.campaign-section{margin-bottom:28px;text-align:left}.campaign-folder-container{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.campaign-folder{display:flex;flex-direction:column;gap:10px}.folder-main{background:#091812e0;border:1px solid #1f7a5a73;border-radius:14px;box-shadow:0 10px 24px #00000052;cursor:pointer;overflow:hidden;transition:transform .15s ease,box-shadow .15s ease}.folder-main:hover{box-shadow:0 14px 30px #0006;transform:translateY(-3px)}.folder-tab{background:linear-gradient(135deg,#145c43,#1f7a5a);font-weight:700;padding:12px 16px}.folder-body,.folder-tab{color:#e6f5ef;text-align:left}.folder-body{min-height:140px;padding:16px}.folder-body p{color:#d7e6de;margin-bottom:14px;margin-top:0}.campaign-role-pill{background:#1f7a5a33;border:1px solid #1f7a5a73;border-radius:999px;color:#dff5ea;display:inline-block;font-size:.8rem;font-weight:700;margin-bottom:10px;padding:6px 10px}.campaign-join-code-display{color:#f2f7f4;font-size:.92rem;margin-top:8px}.delete-campaign-button{width:100%}.modal-overlay{align-items:center;animation:fadeIn .18s ease;background:#000000a6;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.modal-content{animation:popIn .18s ease;background:#fff;border-radius:14px;box-shadow:0 18px 40px #00000059;padding:22px;width:min(500px,92vw)}.modal-content h3{margin-top:0}.modal-content input,.modal-content textarea{border:1px solid #cfcfcf;border-radius:8px;box-sizing:border-box;font-family:inherit;margin-bottom:12px;padding:10px 12px;width:100%}.modal-content textarea{min-height:120px;resize:vertical}.modal-buttons{display:flex;gap:10px;justify-content:flex-end}.campaign-detail-page{text-align:left;width:100%}.campaign-detail-header-card{align-items:flex-start;background:#091812e0;border:1px solid #1f7a5a73;border-radius:16px;color:#e6f5ef;display:flex;gap:16px;justify-content:space-between;margin-bottom:20px;padding:20px}.campaign-detail-header-card h2{margin-bottom:10px;margin-top:0}.campaign-detail-description{color:#d7e6de;margin:0}.campaign-detail-meta{align-items:flex-end;display:flex;flex-direction:column;gap:10px}.campaign-detail{grid-gap:18px;align-items:stretch;display:grid;gap:18px;grid-template-columns:280px 1fr}.file-editor,.file-sidebar{background:#091812e0;border:1px solid #1f7a5a73;border-radius:16px;color:#e6f5ef;padding:16px}.file-sidebar h3{margin-top:0}.campaign-create-file-box{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.campaign-create-file-box input,.campaign-file-name-input,.file-editor input{background:#ffffffeb;border:1px solid #3d5a4e;border-radius:8px;box-sizing:border-box;color:#111;padding:10px 12px;width:100%}.file-item{background:#ffffff0f;border:1px solid #1f7a5a4d;border-radius:10px;cursor:pointer;margin-bottom:10px;padding:12px;transition:background .15s ease,transform .15s ease}.file-item:hover{background:#ffffff1f;transform:translateY(-1px)}.file-item-active{background:#ffffff29;border-color:#e6f5ef73}.file-item-name{font-weight:700}.file-item-visibility{font-size:.82rem;margin-top:6px;opacity:.85}.campaign-hidden-toggle{align-items:center;color:#e6f5ef;display:flex;font-weight:600;justify-content:space-between;margin:14px 0}.campaign-editor-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px}.delete-file-button{background:linear-gradient(135deg,#7a1f1f,#a82a2a);border-color:#8f2d2d}.delete-file-button:hover{background:linear-gradient(135deg,#922727,#b93333)}.campaign-player-file-view h3{margin-bottom:14px;margin-top:0}.campaign-player-file-content{background:#fffffff5;border-radius:12px;color:#111;min-height:240px;padding:16px}.campaign-empty-state,.campaign-empty-text{opacity:.8}.ql-container.ql-snow,.ql-toolbar.ql-snow{background:#fff;color:#111}.ql-editor{min-height:280px}@media (max-width:900px){.campaign-detail{grid-template-columns:1fr}.campaign-detail-header-card{flex-direction:column}.campaign-detail-meta{align-items:flex-start}}.characters-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));margin-top:20px}.character-card{background:linear-gradient(135deg,#0b3d2e,#145c43);border:1px solid #1f7a5a;border-radius:10px;box-shadow:0 4px 10px #00000059;color:#e6f5ef;padding:16px;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease}.character-card:hover{box-shadow:0 8px 18px #00000073;transform:translateY(-4px)}.character-card-top{align-items:center;display:flex;gap:14px}.character-card-portrait{background:#0003;border:1px solid #e6f5ef40;border-radius:10px;box-shadow:0 3px 10px #00000059;height:68px;min-width:68px;object-fit:cover;width:68px}.character-card-portrait-fallback{align-items:center;background:#ffffff14;color:#fff;display:flex;font-size:1.2rem;font-weight:700;justify-content:center}.character-card-text{display:flex;flex-direction:column;min-width:0}.character-name{font-size:1.2rem;font-weight:600;margin-bottom:6px;word-break:break-word}.character-profession{font-size:.9rem;opacity:.85;word-break:break-word}body,html{background-color:hidden;height:100%;margin:0}.notes-page{display:flex;height:100%;overflow:hidden;position:relative;width:100%}.notes-page h2{margin-bottom:20px}.notes-error,.notes-loading{font-size:1rem;padding:24px}.board-hud{display:flex;flex-wrap:wrap;gap:12px;left:32px;pointer-events:none;position:fixed;top:120px;z-index:1200}.board-mode-badge,.board-title-badge{border-radius:999px;box-shadow:0 8px 18px #00000040;font-weight:800;padding:10px 14px}.board-title-badge{background:#0f1915eb;border:1px solid #d4af372e;color:#f0f0f0}.board-mode-badge.editable{background:#1f7a5aeb;border:1px solid #1f7a5a73;color:#e6f5ef}.board-mode-badge.readonly{background:#4e585ceb;border:1px solid #b4bec34d;color:#f2f4f5}.note-form{display:flex;flex-direction:column;gap:10px;margin:0 auto 30px;max-width:400px}.note-form input,.note-form textarea{border:1px solid #444;border-radius:6px;font-family:inherit;padding:10px}.note-form textarea{height:80px;resize:none}.note-form button{background:#d4af37;border:none;border-radius:4px;color:#000;cursor:pointer;font-weight:700;padding:8px}.board{background-color:#5a3e1b;background-image:radial-gradient(#4a2f14 1px,#0000 0);background-size:10px 10px;border-radius:8px;box-shadow:0 20px 60px #0009;cursor:grab;height:700px;overflow:hidden;overscroll-behavior:contain;position:relative;width:100%}.board:active{cursor:grabbing}.board-content{left:0;position:absolute;top:0;transition:transform .12s ease-out}.sticky-note{background:#fff8a6;box-shadow:5px 5px 10px #0006;cursor:grab;min-height:150px;padding:15px;position:absolute;text-align:left;-webkit-user-select:none;user-select:none;width:200px}.view-only-note{cursor:default}.sticky-note:nth-child(2n){transform:rotate(2deg)}.sticky-note h3{margin-top:0}.delete-btn{background:#0000;border:none;cursor:pointer;font-weight:700;position:absolute;right:8px;top:5px}.floating-add-button{background:var(--dg-gradient);border:1px solid #1f7a5a;border-radius:50%;bottom:40px;box-shadow:0 6px 16px #0006;color:#e6f5ef;cursor:pointer;font-size:32px;height:60px;position:fixed;right:40px;transition:transform .15s ease,box-shadow .15s ease;width:60px;z-index:1000}.floating-add-button:hover{background:var(--dg-gradient-hover);box-shadow:0 10px 22px #00000080;transform:translateY(-2px)}.note-modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.note-modal{animation:popIn .2s ease;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0006;padding:30px;width:400px}.note-form-modal{display:flex;flex-direction:column;gap:12px}.note-form-modal input,.note-form-modal textarea{border:1px solid #444;border-radius:6px;font-family:inherit;padding:10px}.note-form-modal textarea{height:100px;resize:none}.note-pin{background:crimson;border-radius:50%;box-shadow:0 0 6px #00000080;cursor:pointer;height:18px;left:50%;position:absolute;top:-10px;transform:translateX(-50%);width:18px}.empty-board-message{background:#fff8a6eb;border-radius:10px;box-shadow:0 6px 18px #00000040;color:#2b2412;font-weight:700;left:80px;padding:14px 18px;position:absolute;top:80px}.connection-layer{left:0;overflow:visible;position:absolute;top:0}.connection-hitbox{cursor:pointer}.character-sheet{display:flex;flex-direction:column;gap:28px;margin:0 auto;max-width:1200px;padding:30px}.sheet-header-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.sheet-header-left,.sheet-header-right{background:linear-gradient(135deg,#0b3d2e,#145c43);border:1px solid #1f7a5a;border-radius:12px;box-shadow:0 6px 16px #0006;color:#e6f5ef;padding:20px}.character-header-main{align-items:flex-start;display:flex;gap:20px}.character-portrait-panel{align-items:flex-start;display:flex;flex-direction:column;gap:12px}.character-portrait-image{background:#00000038;border:1px solid #e6f5ef40;border-radius:12px;box-shadow:0 6px 16px #00000059;height:132px;min-width:132px;object-fit:cover;width:132px}.character-portrait-fallback{align-items:center;background:#ffffff14;color:#fff;display:flex;font-size:2rem;font-weight:700;justify-content:center}.sheet-header-text{flex:1 1;min-width:0}.sheet-name{font-size:1.6rem;font-weight:700}.sheet-profession{font-size:.95rem;margin-top:4px;opacity:.85}.header-bond{padding:6px 4px}.portrait-controls{display:flex;flex-direction:column;gap:8px;width:132px}.portrait-file-input{display:none}.sheet-top-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.sheet-card{background:linear-gradient(135deg,#0b3d2e,#145c43);border:1px solid #1f7a5a;border-radius:12px;box-shadow:0 4px 12px #00000059;color:#e6f5ef;padding:18px;transition:transform .15s ease,box-shadow .15s ease}.sheet-card:hover{box-shadow:0 8px 18px #00000073;transform:translateY(-3px)}.sheet-card-title{border-bottom:1px solid #e6f5ef33;font-size:1.05rem;font-weight:600;margin-bottom:12px;padding-bottom:6px}.stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.stat-box{background:#ffffff0f;border:1px solid #e6f5ef40;border-radius:8px;padding:14px;text-align:center;transition:background .15s ease}.stat-box:hover{background:#ffffff1f}.stat-key{color:#e6f5ef;font-size:.8rem;font-weight:500}.stat-value{color:#fff;font-size:1.3rem;font-weight:700}.bond-row,.derived-row,.skill-row,.subskill-row{padding:8px 4px}.bond-row,.derived-row,.skill-row,.subskill-row{border-radius:6px;display:flex;justify-content:space-between;transition:background .15s ease}.bond-row{align-items:center;font-size:.9rem;padding:6px 4px}.bond-row:hover,.derived-row:hover,.skill-row:hover,.subskill-row:hover{background:#0000004d}.bond-name{font-weight:500}.bond-score{font-weight:600;opacity:.9}.subskills-title{margin-bottom:6px;opacity:.9}.clickable{cursor:pointer}.clickable:active{transform:scale(.98)}.sheet-bottom-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.skills-section{display:flex;flex-direction:column;gap:4px}.skill-row,.subskill-row{border-radius:6px;display:flex;font-size:.9rem;justify-content:space-between;padding:4px 6px;transition:background .15s ease}.skill-row:hover,.subskill-row:hover{background:#0000004d}.subskills-group{margin-top:8px}.subskills-title{font-size:.85rem;font-weight:600;margin:4px 0;opacity:.8}.inventory-placeholder{font-style:italic;opacity:.6;padding-top:8px}.inventory-list{gap:10px;margin-top:8px}.inventory-list,.inventory-row{display:flex;flex-direction:column}.inventory-row{background:#00000040;border:1px solid #333;border-radius:8px;gap:6px;padding:10px}.bond-row input,.derived-row input,.inventory-row input,.sheet-header-left input,.skill-row input,.stat-value input,.subskill-row input{background:#00000059;border:1px solid #444;border-radius:6px;box-sizing:border-box;color:inherit;font-family:inherit;padding:8px;width:100%}.inventory-add,.inventory-remove{border:none;border-radius:6px;cursor:pointer;font-weight:600;padding:8px}.inventory-view-top{display:flex;gap:12px;justify-content:space-between}.inventory-view-name{font-weight:700}.inventory-view-qty{opacity:.8}.inventory-view-notes{font-size:.9rem;margin-top:4px;opacity:.85}.sheet-footer{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.sheet-footer-actions{display:flex;flex-wrap:wrap;gap:12px}.character-action-button{align-items:center;background:linear-gradient(135deg,#0b3d2e,#145c43);border:1px solid #1f7a5a;border-radius:8px;color:#e6f5ef;cursor:pointer;display:inline-flex;font-weight:600;justify-content:center;padding:10px 14px;text-decoration:none}.character-secondary-button{background:linear-gradient(135deg,#2d3b37,#41524c);border-color:#556860}.character-delete-button{align-items:center;background:linear-gradient(135deg,#7d1f1f,#a62929);border:1px solid #8c1f1f;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;justify-content:center;padding:10px 14px}.character-delete-button:hover{filter:brightness(1.08)}@media (max-width:900px){.sheet-bottom-grid,.sheet-header-row,.sheet-top-grid{grid-template-columns:1fr}.character-header-main{flex-direction:column}}
/*!
 * Quill Editor v1.3.7
 * https://quilljs.com/
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{height:1px;left:-100000px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{word-wrap:break-word;box-sizing:border-box;height:100%;line-height:1.42;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap}.ql-editor>*{cursor:text}.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6,.ql-editor ol,.ql-editor p,.ql-editor pre,.ql-editor ul{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;margin:0;padding:0}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"\2022"}.ql-editor ul[data-checked=false],.ql-editor ul[data-checked=true]{pointer-events:none}.ql-editor ul[data-checked=false]>li *,.ql-editor ul[data-checked=true]>li *{pointer-events:all}.ql-editor ul[data-checked=false]>li:before,.ql-editor ul[data-checked=true]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"\2611"}.ql-editor ul[data-checked=false]>li:before{content:"\2610"}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-increment:list-0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9: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 .ql-video{display:block;max-width:100%}.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{direction:rtl;text-align:inherit}.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-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;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{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.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 .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar button.ql-active,.ql-snow .ql-toolbar button:focus,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar button.ql-active,.ql-snow.ql-toolbar button:focus,.ql-snow.ql-toolbar button:hover{color:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill{fill:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:hover .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-stroke.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{fill:#444}.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,.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{display:inline-block;vertical-align:middle}.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:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.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-stroke.ql-thin,.ql-snow .ql-thin{stroke-width:1}.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-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{margin-bottom:5px;margin-top:5px;padding:5px 10px;white-space:pre-wrap}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.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{display:block;margin-top:-1px;top:100%;z-index:1}.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{height:24px;padding:2px 4px;width:24px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid #0000;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{margin-top:-9px;position:absolute;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-font .ql-picker-item[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-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[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-item:before,.ql-snow .ql-picker.ql-header .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[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-item:before,.ql-snow .ql-picker.ql-font .ql-picker-label:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[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-item:before,.ql-snow .ql-picker.ql-size .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[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-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.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{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{border:1px solid #ccc;display:none;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";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{border-right:0;content:"Save";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}.boards-page{padding:20px 0;width:100%}.boards-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.boards-actions{display:flex;flex-wrap:wrap;gap:12px}.create-board-btn,.join-board-btn{background:var(--dg-gradient);border:1px solid #1f7a5a;border-radius:10px;color:#e6f5ef;cursor:pointer;font-weight:700;padding:10px 16px;transition:transform .15s ease,box-shadow .15s ease}.create-board-btn:hover,.join-board-btn:hover{background:var(--dg-gradient-hover);box-shadow:0 8px 18px #00000040;transform:translateY(-1px)}.boards-section{margin-bottom:32px}.boards-section h3{margin-bottom:14px}.boards-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.board-card{background:#141c18e6;border:1px solid #d4af3733;border-radius:12px;box-shadow:0 10px 24px #0003;cursor:pointer;padding:18px;transition:.2s ease}.board-card:hover{background:#1c2620f5;transform:translateY(-2px)}.board-card h3{margin-bottom:12px;margin-top:0}.board-role-pill{background:#d4af3724;border:1px solid #d4af3733;border-radius:999px;color:#e5c968;display:inline-block;font-size:.8rem;font-weight:800;letter-spacing:.04em;margin-bottom:12px;padding:6px 10px}.board-join-code{color:#d7ddd9;margin:0}.muted-text{color:#aeb8b2}.boards-modal-form{display:flex;flex-direction:column;gap:12px}
/*# sourceMappingURL=main.00aa75a6.css.map*/