:root{color:#111;background:radial-gradient(circle at top,rgba(0,0,0,.035),transparent 34%),linear-gradient(135deg,#e5e0d5,#f7f4ee 48%,#d8cfbe);font-family:Trebuchet MS,Segoe Print,sans-serif;line-height:1.5;font-weight:400;--paper: #f7f4ee;--paper-strong: #fffdfa;--ink: #111111;--muted: #625d53;--panel: rgba(255, 255, 255, .74);--edge: rgba(17, 17, 17, .16);--shadow: 6px 6px 0 rgba(17, 17, 17, .09)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100vh}body{color:var(--ink)}button,input,select{font:inherit}button{cursor:pointer}.app-shell{min-height:100dvh;padding:10px;display:flex;flex-direction:column;gap:8px}.module-switch-bar{display:flex;justify-content:flex-end}.loading-shell,.auth-shell{min-height:100vh;display:grid;place-items:center;padding:20px}.lobby-shell{display:flex;flex-direction:column;gap:12px}.lobby-hero,.lobby-panel{border:2px solid var(--ink);border-radius:22px;background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.lobby-hero{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:16px 18px}.lobby-hero-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.lobby-hero h1{margin:0;font-size:clamp(26px,3vw,40px)}.lobby-hero span{color:var(--muted)}.lobby-grid{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:12px}.lobby-panel{padding:16px 18px}.lobby-form{display:flex;flex-direction:column;gap:12px}.room-card-list{display:flex;flex-direction:column;gap:10px}.room-card{border:2px solid var(--edge);border-radius:16px;background:#ffffff73;padding:12px}.world-room-card{background:radial-gradient(circle at top right,rgba(17,17,17,.06),transparent 32%),#ffffff8c;border-color:#11111152}.room-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}.room-card-head strong,.room-card-head span{display:block}.room-card-head span,.room-card-meta span,.lobby-empty{color:var(--muted)}.room-card-meta{display:flex;flex-wrap:wrap;gap:8px 14px;margin-bottom:12px;font-size:12px}.lobby-empty{padding:12px 0}.room-header,.auth-card,.floating-panel,.canvas-shell{border:2px solid var(--ink);border-radius:22px;background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.room-header{display:flex;flex-direction:column;gap:8px;padding:9px 12px}.room-header.collapsed{gap:0;padding-bottom:10px}.room-strip{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.room-brandline{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0}.room-strip-meta{display:flex;flex-wrap:nowrap;justify-content:flex-end;gap:8px;align-items:flex-start}.room-strip-pills{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:5px}.eyebrow{margin:0;text-transform:uppercase;letter-spacing:.16em;font-size:11px}.room-header h1,.auth-card h1{margin:0;font-size:clamp(20px,2.1vw,30px)}.header-copy,.auth-copy span,.story-card span{color:var(--muted)}.room-input,.control-block{display:flex;flex-direction:column;gap:8px;width:100%}.room-input input,.control-block input,.control-block select,.control-block input[type=range],.tool-chip,.primary-button,.secondary-button,.ghost-button,.danger-button,.auth-switch button,.join-button,.logout-button{border:2px solid var(--ink);border-radius:14px;background:var(--paper);padding:10px 12px}.join-button,.logout-button,.primary-button,.secondary-button,.tool-chip,.ghost-button,.danger-button,.auth-switch button{transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.join-button:hover,.logout-button:hover,.primary-button:hover,.secondary-button:hover,.tool-chip:hover,.ghost-button:hover,.danger-button:hover,.auth-switch button:hover{transform:translate(-1px,-1px);box-shadow:3px 3px #1111111a}.room-detail-row{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}.room-detail-tags{display:flex;flex-wrap:wrap;gap:8px;min-width:0}.room-detail-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.invite-note{margin:0;width:100%;max-width:340px;font-size:12px;line-height:1.4;color:var(--muted);text-align:right}.status-pill{padding:5px 9px;border:2px dashed var(--ink);border-radius:999px;background:#ffffff73;font-size:11px;line-height:1.2}.ghost-button{background:transparent}.workspace{display:flex}.photo-wall-module.active{min-height:100dvh;background:radial-gradient(circle at top,rgba(255,255,255,.42),transparent 32%),linear-gradient(180deg,#f7f7f3,#efeee8)}.photo-wall-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid rgba(17,17,17,.1);border-radius:22px;background:#ffffff94;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 10px 24px #0000000f;padding:14px 18px}.photo-wall-topbar.compact{padding:10px 14px}.photo-wall-topbar-copy{display:flex;flex-direction:column;gap:3px}.photo-wall-topbar-copy span{font-size:18px;letter-spacing:.12em;font-weight:300}.photo-wall-topbar-copy small{color:var(--muted);letter-spacing:.04em}.photo-wall-topbar-actions,.photo-wall-topbar-pills{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.photo-wall-workspace-wrap{flex:1 1 auto;min-height:calc(100dvh - 20px)}.photo-wall-stage.fullscreen{width:100%;min-height:calc(100dvh - 20px)}.photo-wall-canvas-shell.immersive{position:relative;min-height:calc(100dvh - 170px);border:0;border-radius:32px;overflow:hidden;touch-action:none;background:linear-gradient(180deg,#ffffff8a,#ffffff14),#f4f4f4;box-shadow:inset 0 1px #ffffffb3,0 24px 60px #00000014}.photo-wall-floating-head{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:4;width:min(960px,calc(100% - 32px));display:flex;justify-content:space-between;gap:12px;align-items:center;padding:10px 14px;border-radius:18px;background:#ffffff85;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 10px 24px #0000000f}.photo-wall-floating-head-copy{display:flex;flex-direction:column;gap:2px}.photo-wall-floating-head-copy strong{font-weight:500;letter-spacing:.08em;font-size:15px}.photo-wall-floating-head-copy small{margin:0;color:#777;font-size:12px}.photo-wall-floating-head-pills{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.photo-wall-canvas.gallery-mode{position:absolute;left:0;top:0;transform-origin:0 0;background:#f4f4f4}.frame-item{transition:transform .4s cubic-bezier(.165,.84,.44,1)}.wall-photo-card{position:absolute;-webkit-user-select:none;user-select:none;cursor:grab}.wall-photo-card:hover{transform:translateY(-10px) rotate(var(--photo-rotate, 0deg))}.wall-photo-card.selected{filter:drop-shadow(0 0 .35rem rgba(17,17,17,.22))}.wall-photo-card img{display:block;width:100%;height:100%;object-fit:cover;pointer-events:none}.classic-wood{width:100%;height:100%;box-sizing:border-box;padding:12px;background-color:#3d2b1f;border:4px solid #2a1d15;box-shadow:0 15px 35px #0000004d}.classic-wood .matting{width:100%;height:100%;box-sizing:border-box;background-color:#fff;padding:25px;box-shadow:inset 0 0 8px #0000001a}.polaroid{background-color:#fff;padding:15px 15px 50px;box-shadow:0 8px 20px #0000001a}.polaroid .caption{text-align:center;font-size:14px;margin-top:15px;color:#555;letter-spacing:1px}.modern-metal{border:2px solid;border-image:linear-gradient(45deg,#af8d19,#f1d37e,#af8d19) 1;padding:8px;background:#fff;box-shadow:0 10px 25px #00000014}.wall-photo-meta-tag{position:absolute;top:10px;right:10px;font-size:11px;color:#333333c7;background:#ffffffc7;border-radius:999px;padding:3px 8px;box-shadow:0 6px 14px #00000014;pointer-events:none;z-index:2}.wall-photo-resize{display:none}.photo-wall-floating-dock{position:absolute;z-index:4;width:min(320px,calc(100vw - 36px));display:flex;flex-direction:column;gap:10px;align-items:flex-end}.photo-wall-actions-dock{right:18px;bottom:18px}.photo-wall-logs-dock{left:18px;bottom:18px;align-items:flex-start}.photo-wall-members-dock{left:106px;bottom:18px;align-items:flex-start}.photo-wall-floating-dock.collapsed{width:auto}.floating-dock-toggle{border:0;border-radius:999px;padding:12px 18px;background:#111111e0;color:#fff;box-shadow:0 16px 32px #00000024}.floating-dock-body{width:100%;border-radius:24px;padding:14px;background:#ffffffd1;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 16px 40px #0000001a;display:flex;flex-direction:column;gap:10px}.floating-dock-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.floating-dock-actions.expanded{grid-template-columns:repeat(3,1fr)}.floating-dock-actions .secondary-button,.floating-dock-actions .ghost-button,.floating-dock-actions .primary-button{width:100%;margin-bottom:0}.floating-dock-meta{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-size:12px}.compact-toggle{width:100%;margin-bottom:0}.floating-card{border-radius:18px;padding:12px;background:#ffffffb8;border:1px solid rgba(17,17,17,.08)}.floating-inline-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.floating-inline-actions .secondary-button,.floating-inline-actions .danger-button{width:100%;margin-bottom:0}.photo-wall-log-list,.photo-wall-member-list{display:flex;flex-direction:column;gap:8px;max-height:220px;overflow:auto}.floating-log-body{width:min(300px,calc(100vw - 36px));max-height:min(280px,42vh)}.photo-wall-log-item{display:flex;flex-direction:column;padding:8px 10px;border-radius:14px;background:#ffffffa8;border:1px solid rgba(17,17,17,.08)}.photo-wall-log-item span,.photo-wall-log-item em{color:var(--muted);font-size:12px}.photo-wall-floating-feedback{position:absolute;left:18px;bottom:88px;z-index:4;max-width:min(420px,calc(100vw - 160px));padding:10px 12px;border-radius:16px;background:#ffffffe0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 16px 34px #00000014}.photo-wall-floating-feedback.error{background:#fff5f5f0}.side-panel-chips.compact{margin-top:0}.camera-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#dcdde1e0;display:grid;place-items:center;overflow-y:auto;-webkit-overflow-scrolling:touch;z-index:50}.camera-scene{position:relative;--eject-start-top: 290px;--eject-mid-shift: 280px;--eject-end-shift: 300px;width:min(92vw,520px);min-height:720px;margin:max(12px,env(safe-area-inset-top)) auto max(24px,env(safe-area-inset-bottom));display:flex;flex-direction:column;align-items:center;justify-content:center}.camera-container{position:relative;width:min(340px,100%);z-index:2}.camera-body{background-color:#ececec;border-radius:40px;padding:30px;box-shadow:0 20px 50px #00000026;position:relative;z-index:3;border-bottom:8px solid #ddd}.camera-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.lens-badge{width:40px;height:40px;background:radial-gradient(#444,#111);border-radius:50%;border:4px solid #ececec;box-shadow:0 0 0 2px #ccc}.flash-unit{width:60px;height:30px;background:#eee;border-radius:5px;box-shadow:inset 0 0 5px #0003;border:1px solid #ddd}.viewfinder{width:100%;height:240px;background-color:#222;border-radius:15px;overflow:hidden;position:relative;border:5px solid #333}.viewfinder video{width:100%;height:100%;object-fit:cover;filter:brightness(.8) contrast(1.1)}.flash-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;opacity:0;pointer-events:none;z-index:10}.controls{margin-top:25px;display:flex;justify-content:space-between;align-items:center}.shutter-btn{width:60px;height:60px;background-color:#ff4d4d;border-radius:50%;border:none;box-shadow:0 4px #b33939,0 8px 15px #0003;cursor:pointer;transition:all .1s;outline:none}.shutter-btn:active{transform:translateY(4px);box-shadow:0 0 #b33939,0 4px 10px #0000001a}.brand{font-weight:700;letter-spacing:2px;color:#aaa;font-size:12px}.film-count{color:#666;font-size:12px}.photo-output-slot{position:absolute;bottom:168px;left:50%;transform:translate(-50%);width:260px;height:10px;background:#222;z-index:1}.printed-photo{position:absolute;top:var(--eject-start-top);left:50%;transform:translate(-50%);width:220px;background:#fff;padding:12px 12px 40px;box-shadow:0 5px 15px #0003;visibility:hidden;z-index:0}.printed-photo img{width:100%;height:200px;object-fit:cover;filter:brightness(0) sepia(1);transition:filter 5s ease-in}.flash-active{animation:flash-anim .3s ease-out}.eject-photo{animation:eject-anim 4s forwards;visibility:visible}.develop-photo{filter:brightness(1) sepia(0)!important}.camera-scene-footer{margin-top:18px;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;color:#7f8c8d;font-size:14px}.camera-switch-btn{margin-bottom:0;width:auto}@keyframes flash-anim{0%{opacity:0}50%{opacity:1}to{opacity:0}}@keyframes eject-anim{0%{transform:translate(-50%);z-index:1}40%{transform:translate(-50%,var(--eject-mid-shift, 280px));z-index:1}to{transform:translate(-50%,var(--eject-end-shift, 300px)) rotate(5deg);z-index:4}}.whiteboard-module.active{min-height:100dvh;padding:0;gap:0}.whiteboard-workspace-wrap{flex:1 1 auto;min-height:100dvh}.board-stage{width:100%;min-width:0}.board-stage.fullscreen{width:100%;min-height:100dvh}.board-canvas-shell.immersive{position:relative;width:100%;min-height:100dvh;height:100dvh;overflow:hidden;isolation:isolate;touch-action:none;background:radial-gradient(circle at top,rgba(255,255,255,.34),transparent 34%),linear-gradient(180deg,#f7f4ee,#ece6dc)}.board-canvas-shell.immersive canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;cursor:crosshair;touch-action:none}.board-floating-head{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:6;width:min(1100px,calc(100% - 32px));display:flex;justify-content:space-between;gap:12px;align-items:center;padding:10px 14px;border-radius:18px;background:#ffffff8f;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 10px 24px #0000000f}.board-floating-head-copy{display:flex;flex-direction:column;gap:2px}.board-floating-head-copy strong{font-weight:600;letter-spacing:.06em;font-size:15px}.board-floating-head-copy small{margin:0;color:#666;font-size:12px}.board-floating-head-pills{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.whiteboard-floating-dock{position:absolute;z-index:6;width:min(320px,calc(100vw - 36px));display:flex;flex-direction:column;gap:10px;align-items:flex-end}.whiteboard-floating-dock.collapsed{width:auto}.whiteboard-actions-dock{right:18px;bottom:18px}.whiteboard-info-dock{left:18px;bottom:18px;align-items:flex-start}.whiteboard-floating-feedback{position:absolute;left:18px;bottom:92px;z-index:6;max-width:min(420px,calc(100vw - 160px));padding:10px 12px;border-radius:16px;background:#ffffffe0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 16px 34px #00000014}.whiteboard-floating-feedback.error{background:#fff5f5f0}.floating-panel{position:absolute;z-index:2;padding:12px;background:#ffffffd1}.side-panel{top:14px;right:14px;width:min(280px,calc(100% - 28px));max-height:calc(100% - 120px);overflow:auto;scrollbar-width:thin;scrollbar-color:rgba(17,17,17,.45) rgba(255,255,255,.22)}.side-panel.collapsed{width:min(200px,calc(100% - 28px));max-height:none;overflow:visible}.side-panel::-webkit-scrollbar{width:10px}.side-panel::-webkit-scrollbar-track{margin:12px 0;border-radius:999px;background:#ffffff2e;box-shadow:inset 0 0 0 1px #11111114}.side-panel::-webkit-scrollbar-thumb{border:2px solid transparent;border-radius:999px;background:linear-gradient(180deg,#11111185,#11111157);background-clip:padding-box}.whiteboard-module.active .side-panel{top:86px;right:18px;max-height:calc(100% - 176px);z-index:6}.side-panel::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#111111b3,#11111175);background-clip:padding-box}.panel-heading{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px}.panel-heading span{font-size:16px;font-weight:700}.panel-heading small{color:var(--muted)}.side-panel-header{display:flex;justify-content:space-between;gap:12px;align-items:center}.side-panel-header span{color:var(--muted);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.side-panel-summary{width:100%;border:0;background:transparent;padding:0;text-align:left}.side-panel-body{margin-top:10px}.side-panel-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.side-panel-chips small{padding:6px 10px;border:2px dashed var(--edge);border-radius:999px;background:#ffffff6b;color:var(--muted)}.dock-section+.dock-section{margin-top:10px}.dock-toggle{width:100%;display:flex;justify-content:space-between;gap:12px;align-items:center;border:2px solid var(--ink);border-radius:14px;background:var(--paper);padding:10px 12px}.dock-toggle span{font-weight:700}.dock-toggle small{color:var(--muted)}.dock-section-body{margin-top:8px}.tool-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.tool-chip.active,.primary-button,.danger-button,.auth-switch button.active{background:var(--ink);color:var(--paper)}.toolbar-note{margin:8px 0 12px;padding:8px 10px;border:2px dashed var(--edge);border-radius:12px;color:var(--muted);background:#fff6}.danger-button{width:100%}.secondary-button{width:100%;margin-bottom:8px;background:#ffffff94}.user-list{display:flex;flex-direction:column;gap:8px}.user-card{display:flex;justify-content:space-between;gap:12px;align-items:start;padding:8px 10px;border:2px solid var(--edge);border-radius:14px;background:#ffffff6b}.user-card strong,.user-card span{display:block}.user-card span,.user-card em{color:var(--muted)}.auth-card{width:min(920px,100%);display:grid;grid-template-columns:1fr 1.1fr;gap:20px;padding:22px}.auth-copy{display:flex;flex-direction:column;gap:10px;justify-content:center}.auth-switch{display:flex;gap:8px}.auth-form{display:flex;flex-direction:column;gap:12px}.primary-button{margin-top:4px}.form-error{padding:8px 10px;border:2px solid var(--ink);border-radius:12px;background:#11111114}.password-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#11111173;display:grid;place-items:center;padding:16px}.password-modal-card{width:min(460px,100%);border:2px solid var(--ink);border-radius:20px;background:#fffffff2;box-shadow:0 20px 45px #0003;padding:16px;display:flex;flex-direction:column;gap:10px}.password-modal-card h3{margin:0;font-size:20px}.password-modal-card p{margin:0;color:var(--muted)}.password-modal-actions{display:flex;justify-content:flex-end;gap:8px}.room-chip{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-toggle{padding:7px 10px;flex:0 0 auto}.user-chip,.identity-email{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.join-button,.logout-button{white-space:nowrap;width:auto}.room-detail-actions .secondary-button,.room-detail-actions .ghost-button{margin-bottom:0}.room-detail-actions .secondary-button{width:auto}.compact-room-input{min-width:0}.inline-feedback{padding:7px 10px;border:2px solid var(--ink);border-radius:12px;font-size:13px;background:#1111110f}.inline-feedback.success{background:#11111114}.inline-feedback.error{background:#0000001f}@media (max-width: 1360px),(max-height: 920px){.room-strip{flex-direction:column;align-items:stretch}.room-strip-meta{width:100%;justify-content:space-between;align-items:center}.room-strip-pills{justify-content:flex-start}.room-detail-row{flex-direction:column;align-items:stretch}.room-detail-actions{justify-content:flex-start}.invite-note{max-width:none;text-align:left}.side-panel.tight-screen{width:min(280px,calc(100% - 32px));max-height:calc(100% - 104px)}.side-panel.tight-screen.collapsed{width:min(210px,calc(100% - 32px))}.lobby-grid{grid-template-columns:1fr}}@media (max-height: 820px){.app-shell{padding:10px}.workspace{gap:0}.canvas-shell{height:clamp(460px,72dvh,860px);min-height:460px}.side-panel.tight-screen{top:12px;right:12px;max-height:calc(100% - 92px)}}@media (max-width: 960px){.auth-card{grid-template-columns:1fr;gap:14px;padding:18px}.app-shell{padding:8px;gap:8px}.room-header{gap:8px;padding:9px 11px;border-radius:20px}.workspace{gap:0}.photo-wall-canvas-shell.immersive{min-height:calc(100dvh - 32px);border-radius:24px}.board-floating-head{top:12px;width:calc(100% - 24px);align-items:flex-start;flex-direction:column}.board-floating-head-pills{justify-content:flex-start}.whiteboard-floating-dock{width:min(300px,calc(100vw - 24px))}.whiteboard-actions-dock{right:12px;bottom:12px}.whiteboard-info-dock{left:12px;bottom:12px}.whiteboard-floating-feedback{left:12px;right:12px;bottom:78px;max-width:none}.whiteboard-module.active .side-panel{top:92px;right:12px;width:min(82vw,310px);max-height:calc(100% - 188px)}.photo-wall-floating-head{top:12px;width:calc(100% - 24px);align-items:flex-start;flex-direction:column}.photo-wall-floating-head-pills{justify-content:flex-start}.photo-wall-floating-dock{width:min(300px,calc(100vw - 24px))}.photo-wall-actions-dock{right:12px;bottom:12px}.photo-wall-logs-dock{left:12px;bottom:12px}.photo-wall-members-dock{left:96px;bottom:12px}.camera-scene{min-height:640px}.side-panel{position:absolute;margin:0}.canvas-shell{height:clamp(420px,74dvh,820px);min-height:420px}.canvas-shell canvas{position:absolute}.side-panel{top:12px;right:12px;width:min(82vw,310px);max-height:calc(100% - 92px)}.side-panel.compact-screen.collapsed{width:auto;max-width:calc(100% - 24px)}.tool-grid{grid-template-columns:1fr 1fr}.user-card{padding:10px}.room-detail-row{flex-direction:column}}@media (max-width: 640px){.lobby-hero{flex-direction:column;align-items:stretch;padding:14px}.lobby-hero-actions{justify-content:stretch}.lobby-panel{padding:12px 14px}.room-header{gap:8px;padding:8px 9px;border-radius:18px}.room-header h1{font-size:18px}.workspace{gap:0}.photo-wall-canvas-shell.immersive{min-height:calc(100dvh - 16px);border-radius:20px}.board-floating-head{top:10px;width:calc(100% - 20px);padding:8px 10px;border-radius:16px;gap:6px}.board-floating-head-copy strong{font-size:14px}.board-floating-head-copy small{font-size:11px}.board-floating-head-pills{gap:4px}.board-floating-head .status-pill{padding:4px 7px;font-size:10px}.whiteboard-floating-dock{width:min(180px,calc(100vw - 20px))}.whiteboard-floating-feedback{left:10px;right:10px;bottom:74px;max-width:none}.whiteboard-actions-dock{right:10px;bottom:14px}.whiteboard-info-dock{left:10px;bottom:14px}.whiteboard-module.active .side-panel{top:88px;right:10px;width:min(86vw,300px);max-height:calc(100% - 182px)}.photo-wall-floating-head{top:10px;width:calc(100% - 20px);padding:8px 10px;border-radius:16px;gap:6px}.photo-wall-floating-head-copy strong{font-size:14px}.photo-wall-floating-head-copy small{font-size:11px}.photo-wall-floating-head-pills{gap:4px}.photo-wall-floating-head .status-pill{padding:4px 7px;font-size:10px}.photo-wall-floating-dock{width:min(180px,calc(100vw - 20px))}.floating-dock-body{padding:8px;border-radius:16px;gap:8px;max-height:min(58vh,calc(100dvh - 120px));overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.floating-dock-actions,.floating-dock-actions.expanded,.floating-inline-actions{grid-template-columns:1fr}.floating-card{padding:10px;border-radius:14px}.floating-card .control-block{gap:6px}.floating-card .control-block span{font-size:12px}.floating-card input,.floating-card select,.floating-card .secondary-button,.floating-card .danger-button,.floating-card .ghost-button,.floating-card .primary-button{padding:8px 10px}.floating-dock-toggle{padding:10px 14px;font-size:13px}.photo-wall-floating-feedback{left:10px;right:10px;bottom:74px;max-width:none}.photo-wall-actions-dock{right:10px;bottom:14px}.photo-wall-logs-dock{left:10px;bottom:14px}.photo-wall-members-dock{left:82px;bottom:14px}.floating-log-body{width:min(180px,calc(100vw - 20px));max-height:24vh;padding:8px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.floating-dock-body::-webkit-scrollbar,.floating-log-body::-webkit-scrollbar{width:8px}.floating-dock-body::-webkit-scrollbar-thumb,.floating-log-body::-webkit-scrollbar-thumb{border-radius:999px;background:#1111112e}.floating-dock-body::-webkit-scrollbar-track,.floating-log-body::-webkit-scrollbar-track{background:transparent}.photo-wall-log-item{padding:7px 8px;border-radius:10px}.photo-wall-log-item strong{font-size:12px}.photo-wall-log-item span,.photo-wall-log-item em{font-size:10px}.camera-scene{--eject-start-top: 210px;--eject-mid-shift: 190px;--eject-end-shift: 210px;width:min(94vw,360px);min-height:560px;margin:max(10px,env(safe-area-inset-top)) auto max(18px,env(safe-area-inset-bottom))}.camera-container{width:100%}.camera-body{border-radius:28px;padding:20px}.viewfinder{height:200px}.printed-photo{width:180px}.printed-photo img{height:170px}.canvas-meta{padding:0 4px;font-size:12px}.canvas-shell{height:clamp(380px,72dvh,720px);min-height:380px;border-radius:18px}.floating-panel{padding:8px 10px;border-radius:14px}.side-panel{top:10px;right:10px;width:min(86vw,300px);max-height:calc(100% - 82px)}.side-panel.compact-screen.collapsed .side-panel-chips{margin-top:6px}.dock-toggle,.room-input input,.control-block input,.tool-chip,.primary-button,.secondary-button,.ghost-button,.danger-button,.auth-switch button,.join-button,.logout-button{padding:10px 12px}.tool-grid{gap:8px}.side-panel-chips{gap:6px}.header-copy,.identity-email{display:none}.room-detail-row{gap:8px}.room-strip-meta{align-items:stretch;flex-direction:column;gap:6px}.room-strip-pills{justify-content:flex-start}.status-pill{padding:5px 8px;font-size:11px}}@media (max-width: 520px),(max-height: 700px){.room-header{padding:8px 10px;gap:8px}.canvas-meta{font-size:12px}.canvas-shell{height:clamp(340px,68dvh,620px);min-height:340px}.side-panel{top:8px;right:8px;width:min(88vw,280px);max-height:calc(100% - 74px)}.whiteboard-module.active .side-panel{top:84px;right:8px;width:min(88vw,280px);max-height:calc(100% - 176px)}.side-panel.collapsed{width:min(210px,calc(100% - 16px))}.floating-panel{box-shadow:6px 6px #1111111a}.room-brandline{gap:6px 10px}.room-detail-row{flex-direction:column}.room-detail-actions{flex-direction:column;align-items:stretch}.invite-note{font-size:11px}.join-button,.logout-button{width:100%}}
