*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f1ece3;--surface: #f9f5ed;--surface-strong: #fffcf6;--sidebar-w: 240px;--topbar-h: 48px;--accent: #c67c5b;--accent-hover: #b86d4c;--danger: #bc4339;--text: #1f2430;--muted: #67707d;--border: #d7d7d1;--radius: 12px;--shadow-soft: 0 14px 40px rgba(31, 36, 48, .09);--grain-a: rgba(255, 255, 255, .52);--grain-b: rgba(31, 36, 48, .04)}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Avenir Next,Segoe UI,Helvetica Neue,sans-serif;background:radial-gradient(1200px 600px at -10% -20%,#fdf8ef 0%,transparent 60%),radial-gradient(900px 460px at 115% 110%,#e5ded1 0%,transparent 58%),linear-gradient(180deg,#f2ece2,#ebe4d7);color:var(--text)}.loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1.2rem;color:var(--muted)}.auth-wrapper{display:flex;align-items:center;justify-content:center;min-height:100vh;background:radial-gradient(500px 280px at 8% 18%,rgba(198,124,91,.18),transparent 70%),radial-gradient(440px 260px at 88% 78%,rgba(124,143,122,.16),transparent 70%)}.auth-box{background:linear-gradient(180deg,var(--surface-strong) 0%,var(--surface) 100%);border:1px solid rgba(215,215,209,.9);border-radius:16px;box-shadow:var(--shadow-soft);padding:2rem 2.4rem;width:100%;max-width:430px}.auth-title{font-family:Iowan Old Style,Palatino Linotype,Book Antiqua,serif;font-size:2rem;font-weight:700;letter-spacing:.015em;text-align:center;margin-bottom:.35rem}.auth-subtitle{text-align:center;font-size:.9rem;line-height:1.45;color:var(--muted);margin-bottom:1.25rem}.auth-tabs{display:flex;gap:.5rem;margin-bottom:1.25rem}.auth-tabs button{flex:1;padding:.5rem;border:1px solid var(--border);border-radius:var(--radius);background:none;cursor:pointer;font-size:.95rem;color:var(--muted);transition:background .15s,color .15s}.auth-tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.auth-form{display:flex;flex-direction:column;gap:.9rem}.auth-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.9rem;font-weight:500}.auth-form input{padding:.55rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:1rem;outline:none;transition:border-color .15s}.auth-form input:focus{border-color:var(--accent)}.auth-error{color:var(--danger);font-size:.875rem}.btn-primary{padding:.5rem 1.1rem;background:linear-gradient(180deg,#cf8765 0%,var(--accent) 100%);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:.9rem;font-weight:600;box-shadow:0 8px 20px #c67c5b38;transition:background .15s,transform .15s,box-shadow .15s}.btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#c67c5b 0%,var(--accent-hover) 100%);transform:translateY(-1px);box-shadow:0 10px 24px #c67c5b47}.btn-primary:disabled{opacity:.6;cursor:default}.btn-secondary{padding:.5rem 1rem;background:#fff9;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:.9rem;transition:background .15s}.btn-secondary:hover{background:#fff}.btn-xs{padding:.28rem .55rem;font-size:.75rem;line-height:1.15}.btn-icon{background:none;border:none;cursor:pointer;padding:.25rem .4rem;font-size:1rem;border-radius:4px;line-height:1;transition:background .15s}.btn-icon:hover{background:var(--border)}.btn-delete{color:var(--danger);opacity:0;transition:opacity .15s}.app{display:flex;height:100vh;overflow:hidden}.app.app-dark{--text: #e3e3e8;--muted: #c4c4cc;--border: #4a4a51;--bg: #333333;--surface: #333333;--surface-strong: #333333;background:#333;color:#e3e3e8}.app.app-dark .sidebar,.app.app-dark .topbar,.app.app-dark .modal,.app.app-dark .admin-table th{background:#333;color:#e3e3e8}.app.app-dark .sidebar,.app.app-dark .topbar,.app.app-dark .sidebar-header,.app.app-dark .sidebar-item,.app.app-dark .modal,.app.app-dark .modal-header,.app.app-dark .admin-table th,.app.app-dark .admin-table td{border-color:#4a4a51}.app.app-dark .sidebar-item:hover{background:#3a3a3a}.app.app-dark .sidebar-item.active{background:#3f3f3f}.app.app-dark .drawing-name:hover,.app.app-dark .drawing-name:focus,.app.app-dark .share-link-input{background:#2b2b31;color:#e3e3e8}.app.app-dark .drawing-name{color:#e3e3e8}.app.app-dark .btn-primary,.app.app-dark .btn-secondary,.app.app-dark .btn-danger,.app.app-dark .btn-icon{background:#232329;color:#e3e3e8;border:1px solid #3b3b44;box-shadow:none}.app.app-dark .btn-primary:hover:not(:disabled),.app.app-dark .btn-secondary:hover:not(:disabled),.app.app-dark .btn-danger:hover:not(:disabled),.app.app-dark .btn-icon:hover:not(:disabled){background:#2e2e36}.app.app-dark .topbar-user,.app.app-dark .autosave-toggle,.app.app-dark .status-msg,.app.app-dark .sidebar-info,.app.app-dark .sidebar-storage,.app.app-dark .auth-pending,.app.app-dark .share-hint{color:#e3e3e8}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:linear-gradient(180deg,#ffffff9e,#ffffff73),repeating-linear-gradient(45deg,transparent 0px,transparent 10px,var(--grain-b) 10px,var(--grain-b) 11px);border-right:1px solid rgba(199,199,191,.75);display:flex;flex-direction:column;overflow:hidden;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.sidebar-title{font-weight:600;font-size:.9rem}.sidebar-list{flex:1;overflow-y:auto;padding:.5rem 0}.sidebar-info{font-size:.85rem;color:var(--muted);padding:.5rem 1rem}.sidebar-item{display:flex;align-items:center;cursor:pointer;padding:.4rem .75rem;border-bottom:1px solid var(--border);transition:background .1s}.sidebar-item:hover{background:var(--bg)}.sidebar-item.active{background:linear-gradient(90deg,#c67c5b33,#c67c5b12)}.sidebar-item:hover .btn-delete{opacity:1}.sidebar-item-name{font-size:.875rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-storage{border-top:1px solid var(--border);padding:.55rem .8rem;font-size:.78rem;color:var(--muted);background:#ffffffb8}.board-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:var(--topbar-h);display:flex;align-items:center;gap:.75rem;padding:0 1rem;background:linear-gradient(180deg,#fffcf6f5,#f9f5edf5),linear-gradient(90deg,transparent 0%,var(--grain-a) 50%,transparent 100%);border-bottom:1px solid rgba(199,199,191,.75);flex-shrink:0}.drawing-name{flex:1;max-width:280px;padding:.35rem .6rem;border:1px solid transparent;border-radius:var(--radius);font-size:.95rem;font-weight:600;background:transparent;outline:none;transition:border-color .15s}.drawing-name:hover,.drawing-name:focus{border-color:var(--border);background:#ffffffbf}.status-msg{font-size:.85rem;color:var(--accent);font-weight:500}.topbar-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.topbar-user{font-size:.85rem;color:var(--muted)}.autosave-toggle{display:flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.autosave-toggle input{accent-color:#7c8f7a;cursor:pointer}.excalidraw-extra-tools{display:flex;align-items:center;gap:.3rem;padding:.36rem;border:1px solid var(--border);border-radius:12px;background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:100%;box-sizing:border-box}.tool-icon-btn,.tool-color-btn{width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px;background:#ffffffe6;color:var(--text);cursor:pointer;transition:border-color .12s ease,background-color .12s ease}.tool-icon-btn:hover,.tool-color-btn:hover{border-color:#9ea89a;background:#f8f9f6}.tool-icon-btn svg{width:1.02rem;height:1.02rem;stroke:currentColor;stroke-width:1.85;fill:none;stroke-linecap:round;stroke-linejoin:round}.tool-color-btn{position:relative;overflow:hidden}.tool-color-btn input[type=color]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;width:100%;height:100%;border:0;cursor:pointer}.tool-color-swatch{width:1rem;height:1rem;border-radius:50%;border:1px solid rgba(0,0,0,.2);background:var(--tool-color, #fff59d)}.app.app-dark .excalidraw-extra-tools{background:#232329eb;border-color:#3b3b44}.app.app-dark .tool-icon-btn,.app.app-dark .tool-color-btn{background:#3d3d46e6;border-color:#555865;color:#ececf4}.app.app-dark .tool-icon-btn:hover,.app.app-dark .tool-color-btn:hover{background:#494953f2;border-color:#787b8d}.excalidraw-tools-fallback{position:absolute;top:12px;right:12px;z-index:25}.Island.App-menu__left .panelColumn .excalidraw-extra-tools{margin-top:.45rem;justify-content:flex-start;flex-wrap:wrap}.guest-badge{background:#7c8f7a;color:#fff;font-size:.7rem;font-weight:700;padding:.2rem .5rem;border-radius:4px;white-space:nowrap;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:linear-gradient(180deg,var(--surface-strong),var(--surface));border:1px solid rgba(215,215,209,.9);border-radius:14px;padding:1.5rem;width:min(440px,90vw);box-shadow:var(--shadow-soft);position:relative;display:flex;flex-direction:column;gap:.75rem}.modal h3{font-size:1.1rem;font-weight:600}.modal-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--muted);line-height:1;padding:.1rem .25rem}.modal-close:hover{color:var(--text)}.share-hint{font-size:.85rem;color:var(--muted);line-height:1.5}.share-permission{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem}.share-permission label{display:flex;align-items:center;gap:.45rem}.share-link-row{display:flex;gap:.5rem}.share-link-input{flex:1;padding:.4rem .6rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.8rem;color:var(--text);background:var(--bg);min-width:0}.btn-danger{background:var(--danger);color:#fff;border:none;padding:.45rem .9rem;border-radius:var(--radius);cursor:pointer;font-size:.85rem;font-weight:500;align-self:flex-start}.btn-danger:hover:not(:disabled){filter:brightness(.88)}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.excalidraw-wrapper{flex:1;position:relative;overflow:hidden}.excalidraw-wrapper>div{width:100%!important;height:100%!important}.admin-modal{width:min(680px,95vw);padding:0}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border);font-size:1rem}.admin-info{padding:1rem;font-size:.9rem;color:var(--muted)}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th,.admin-table td{padding:.55rem .9rem;text-align:left;border-bottom:1px solid var(--border)}.admin-table th{font-weight:600;background:var(--bg)}.admin-date{color:var(--muted);font-size:.8rem;white-space:nowrap}.admin-actions{display:flex;gap:.4rem}.btn-sm{padding:.3rem .65rem;font-size:.78rem}.admin-section-title{padding:.6rem .9rem .25rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.admin-badge{display:inline-block;border-radius:10px;padding:.1rem .55rem;font-size:.75rem;font-weight:700}.badge-active{background:#d1fae5;color:#065f46}.badge-disabled{background:#fee2e2;color:#991b1b}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.auth-pending{padding:1rem 0;display:flex;flex-direction:column;gap:.8rem;font-size:.9rem;line-height:1.5;color:var(--text)}@media (max-width: 860px){.sidebar{width:200px}.topbar{flex-wrap:wrap;height:auto;padding:.55rem .8rem;row-gap:.5rem}.drawing-name{max-width:none;min-width:180px}.topbar-actions{width:100%;justify-content:flex-end}}
