:root{color-scheme:light;--bg-from: #e0f2fe;--bg-to: #eef2ff;--bg-page: #f9fafb;--card-bg: #ffffff;--card-border: #e5e7eb;--card-shadow: 0 24px 60px rgba(15, 23, 42, .1);--text-main: #0f172a;--text-muted: #6b7280;--text-accent: #4f46e5;--primary: #2563eb;--primary-dark: #1d4ed8;--primary-soft: #eff6ff;--danger: #dc2626;--danger-soft: #fee2e2}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{min-height:100vh;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Noto Sans JP,Hiragino Sans,Yu Gothic,sans-serif;color:var(--text-main);background:radial-gradient(circle at top left,var(--bg-from),transparent 55%),radial-gradient(circle at bottom right,var(--bg-to),transparent 50%),var(--bg-page)}.page{min-height:100vh;padding:32px 16px 80px;display:flex;flex-direction:column;align-items:center}.step-indicator{width:100%;max-width:960px;margin:0 0 12px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-accent)}.box,.policy-card{width:100%;max-width:960px;margin-top:8px;background-color:var(--card-bg);border-radius:24px;border:1px solid var(--card-border);padding:28px 28px 32px;box-shadow:var(--card-shadow)}.page h1{margin:0 0 12px;font-size:28px;font-weight:700}.page h2{margin:24px 0 8px;font-size:18px;font-weight:600}.lead{margin:0 0 20px;font-size:14px;line-height:1.9;color:var(--text-muted)}.list{margin:0 0 20px 1.25rem;padding:0;font-size:14px;color:var(--text-main)}.instruction-list{margin:0 0 20px .8rem;padding:0;list-style:none}.instruction-list>li{margin:0;padding-left:1rem;position:relative;line-height:1.8}.instruction-list>li+li{margin-top:12px}.instruction-list>li:before{content:"";position:absolute;left:0;top:.9em;transform:translateY(-50%);width:.34rem;height:.34rem;border-radius:50%;background:var(--text-accent)}.instruction-list>li.no-marker:before{content:none}.sub-list{margin:8px 0 0 .25rem;padding-left:1rem;list-style:disc}.sub-list li+li{margin-top:6px}.meeting-instruction-box{display:flex;flex-direction:column;min-height:0;max-height:calc(100dvh - 44px);padding:14px 20px 12px}.meeting-instruction-content{min-height:0;overflow:hidden;padding-right:0;display:flex;flex-direction:column}.meeting-instruction-actions{margin-top:8px;flex-shrink:0}.meeting-instruction-page h1{margin:0 0 8px;font-size:28px}.meeting-instruction-page .lead{margin-bottom:10px;line-height:1.45}.meeting-instruction-page .instruction-list{margin-bottom:8px}.meeting-instruction-page .instruction-list>li{line-height:1.45}.meeting-instruction-page .instruction-list>li+li{margin-top:7px}.meeting-instruction-page .sub-list{margin-top:4px}.meeting-instruction-page .sub-list li+li{margin-top:3px}.meeting-instruction-page .instruction-list>li.note-line{padding-top:1em;padding-bottom:0;margin-bottom:1em}.meeting-instruction-page .section-title{padding-top:0;padding-bottom:1em}.meeting-instruction-page .section-line .sub-list{margin-top:0}.instruction-section-scroll{min-height:0;flex:1;overflow-y:auto;padding-right:4px}.section-list{margin-top:0;margin-bottom:0}.form{margin-top:8px;display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:4px;font-size:14px}.field input,.field select,.field textarea{padding:9px 12px;border-radius:10px;border:1px solid var(--card-border);background-color:#f9fafb;font:inherit;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 1px var(--primary-soft);background-color:#fff}.file-info{margin:4px 0 0;font-size:12px;color:var(--text-muted)}.checkbox{display:flex;align-items:center;gap:8px;font-size:14px;margin-top:8px}.checkbox input{width:16px;height:16px}.field-error,.error{margin-top:4px;font-size:12px;color:var(--danger)}.alert{padding:8px 12px;border-radius:12px;background-color:var(--danger-soft);color:var(--danger);font-size:13px}.info{margin-top:4px;font-size:13px;color:var(--text-muted)}.hint{margin-top:8px;font-size:13px;color:var(--text-muted)}.actions{margin-top:24px;display:flex;justify-content:flex-end;gap:12px}button{font:inherit;border-radius:999px;padding:8px 18px;border:1px solid transparent;background-color:#f3f4f6;color:var(--text-main);cursor:pointer;transition:background-color .15s ease,color .15s ease,box-shadow .15s ease,transform .05s ease}button:hover:not(:disabled){background-color:#e5e7eb}button:active:not(:disabled){transform:translateY(1px)}button.primary{background-image:linear-gradient(90deg,#4f46e5,#2563eb);color:#fff;box-shadow:0 8px 20px #2563eb59}button.primary:hover:not(:disabled){background-image:linear-gradient(90deg,#4338ca,#1d4ed8)}button:disabled,button.primary:disabled{opacity:.6;box-shadow:none;cursor:default}.summary{margin-top:20px;font-size:14px}.application-id,.passphrase{font-size:20px;font-weight:600}.share-snippet{margin-top:8px;padding:10px 12px;border-radius:14px;background-color:#f3f4f6;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;white-space:pre-wrap}.loading{margin-top:8px;font-size:13px;color:var(--text-muted)}.teams-url a{word-break:break-all;color:var(--primary)}.meeting-top{position:relative;width:100%;padding-bottom:72px;overflow:hidden}.meeting-top:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 20%,rgba(125,211,252,.22),transparent 25%),radial-gradient(circle at 88% 85%,rgba(167,139,250,.16),transparent 32%);pointer-events:none}.meeting-top .step-indicator{max-width:980px;margin:0 auto 12px;color:#22d3ee}.meeting-top .retro-shell{--retro-bg: linear-gradient( 165deg, rgba(15, 23, 42, .95) 0%, rgba(30, 41, 59, .92) 45%, rgba(15, 23, 42, .98) 100% );position:relative;width:min(680px,100%);margin:0 auto;padding:22px;border-radius:24px;border:3px solid #93c5fd;background:var(--retro-bg);box-shadow:0 22px 40px #0f172a73,inset 0 0 0 2px #0ea5e940;color:#f8fafc;overflow:hidden}.meeting-top .retro-shell:before,.meeting-top .retro-shell:after{content:"";position:absolute;pointer-events:none}.meeting-top .retro-shell:before{inset:0;background:linear-gradient(rgba(14,165,233,.18) 1px,transparent 1px) top / 100% 4px repeat-x;opacity:.65}.meeting-top .retro-shell:after{inset:6px;border:2px dashed rgba(56,189,248,.35);border-radius:18px}.meeting-top .retro-scanline{position:absolute;width:100%;height:4px;top:40%;left:0;background:linear-gradient(90deg,transparent,rgba(6,182,212,.45),transparent);opacity:.7;animation:retro-scan 2.8s ease-in-out infinite}.meeting-top .retro-badge{position:relative;margin:0 0 16px;display:inline-block;padding:4px 10px;border:2px solid rgba(56,189,248,.7);border-radius:999px;color:#67e8f9;font-size:11px;letter-spacing:.16em;text-transform:uppercase;background:#0e749040}.meeting-top .retro-title{position:relative;margin:0 0 12px;font-size:28px;line-height:1.3;color:#f8fafc;text-shadow:0 0 12px rgba(14,165,233,.45)}.meeting-top .retro-lead{position:relative;margin:0 0 18px;color:#cbd5e1;font-size:14px;line-height:1.8}.meeting-top .retro-status{position:relative;padding:12px;border-radius:16px;background:#0284c729;border:1px solid rgba(56,189,248,.35);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.meeting-top .retro-status .info-label{margin:0 0 4px;color:#7dd3fc;font-size:12px;letter-spacing:.08em}.meeting-top .retro-status .info{margin:0;color:#f8fafc;font-size:15px;font-weight:700}.meeting-top .error{margin-top:14px}.meeting-top .actions{margin-top:20px;display:flex;justify-content:stretch}.meeting-top .actions .primary{width:100%;border:2px solid rgba(96,165,250,.8);border-radius:999px;background:linear-gradient(90deg,#1d4ed8,#2563eb 72%,#0ea5e9);text-shadow:0 1px 0 rgba(15,23,42,.25);box-shadow:0 0 0 3px #7dd3fc2e,0 8px 24px #3b82f673}.meeting-top .actions .primary:hover:not(:disabled){transform:translateY(-1px)}@keyframes retro-scan{0%{transform:translateY(-220%);opacity:0}20%{opacity:.8}80%{opacity:0}to{transform:translateY(220%);opacity:0}}@media(min-width:768px){.page{padding-top:40px}.box,.policy-card{padding:32px 40px 40px}.page h1{font-size:30px}.meeting-top .retro-shell{margin-top:16px;padding:28px 34px 34px}.meeting-top h1.retro-title{font-size:36px}.meeting-top .retro-lead{font-size:15px}.meeting-top .actions .primary{width:auto;min-width:240px}.meeting-top .actions{justify-content:flex-end}}@media(min-width:1024px){.meeting-top .retro-shell{width:min(860px,100%);padding:40px 48px 44px}.meeting-top .retro-title{font-size:44px}.meeting-top .retro-lead{font-size:16px;line-height:1.9}.meeting-top .retro-status .info{font-size:17px}.meeting-top .retro-status .info-label{font-size:13px}.meeting-top .actions .primary{min-width:260px;padding-top:12px;padding-bottom:12px}.meeting-top .retro-badge{margin-bottom:18px}}.section{margin-top:24px;padding-top:18px;border-top:1px solid var(--card-border)}.section:first-of-type{margin-top:8px;padding-top:0;border-top:none}.section-description{margin:0 0 8px;font-size:13px;color:var(--text-muted)}.instruction-video .video-wrapper{width:100%;max-width:720px;margin:12px auto 0;aspect-ratio:16 / 9;background:#000;border-radius:12px;overflow:hidden}.instruction-video .video-wrapper video{width:100%;height:100%;display:block;object-fit:contain}html,body,#root{height:100dvh;overflow:hidden}body{min-height:100dvh}.page{height:100dvh;min-height:100dvh;padding:clamp(8px,1.3vh,16px) clamp(10px,2vw,20px) clamp(8px,1.3vh,16px);overflow:hidden}.step-indicator{margin:0 0 clamp(4px,1vh,10px);font-size:clamp(11px,1.3vw,13px)}.box,.policy-card{margin-top:0;max-height:calc(100dvh - clamp(56px,12vh,112px));padding:clamp(12px,2vh,24px) clamp(12px,2vw,28px);overflow:hidden}.page h1{margin:0 0 clamp(6px,1vh,12px);font-size:clamp(22px,3.4vw,30px)}.page h2{margin:clamp(12px,2vh,20px) 0 clamp(6px,1vh,8px);font-size:clamp(16px,2.1vw,18px)}.lead{margin:0 0 clamp(12px,2vh,20px);font-size:clamp(13px,1.8vw,14px);line-height:1.7}.list{margin:0 0 clamp(12px,2vh,20px) 1.1rem;font-size:clamp(13px,1.8vw,14px)}.instruction-list{margin:0 0 clamp(10px,1.8vh,16px) .4rem}.instruction-list>li{line-height:1.7}.sub-list{margin-top:6px}.sub-list li+li{margin-top:4px}.meeting-instruction-actions{margin-top:clamp(8px,1.3vh,14px)}.meeting-instruction-page{padding-top:clamp(6px,1vh,10px);padding-bottom:clamp(6px,1vh,10px)}.meeting-instruction-page .meeting-instruction-box{max-height:calc(100dvh - clamp(44px,8vh,76px));padding:clamp(10px,1.5vh,14px) clamp(14px,2vw,20px) clamp(8px,1.2vh,12px)}.meeting-instruction-page h1{margin:0 0 clamp(3px,.7vh,8px);font-size:clamp(22px,3vw,28px)}.meeting-instruction-page .lead{margin:0 0 clamp(6px,1vh,10px);font-size:clamp(13px,1.4vw,14px);line-height:1.35}.meeting-instruction-page .instruction-list{margin:0 0 clamp(4px,.8vh,8px) .35rem;font-size:clamp(13px,1.55vw,15px)}.meeting-instruction-page .instruction-list>li{line-height:1.4}.meeting-instruction-page .instruction-list>li+li{margin-top:clamp(4px,.9vh,7px)}.meeting-instruction-page .sub-list{margin-top:clamp(2px,.4vh,4px)}.meeting-instruction-page .sub-list li+li{margin-top:clamp(2px,.3vh,3px)}.meeting-instruction-page .meeting-instruction-actions{margin-top:clamp(5px,.8vh,8px)}.form{margin-top:0;gap:clamp(10px,1.5vh,14px)}.field{font-size:clamp(13px,1.7vw,14px)}.field input,.field select,.field textarea{padding:clamp(7px,1.2vh,9px) 11px}.actions,.summary{margin-top:clamp(12px,2vh,20px)}.meeting-top{padding-bottom:0}.meeting-top .retro-shell{margin-top:0;max-height:calc(100dvh - clamp(56px,12vh,110px))}.complete-page .box{overflow-y:auto}.meeting-device-test-page .lead{margin-bottom:clamp(6px,1vh,14px)}.device-test-box{display:flex;flex-direction:column;overflow:hidden}.device-test-body{display:flex;gap:clamp(12px,2vw,24px);min-height:0;flex:1}.device-test-video-wrapper{flex:1;min-width:0;border-radius:12px;background:#1e293b;overflow:hidden;aspect-ratio:4/3;max-height:clamp(160px,36vh,320px);align-self:flex-start}.device-test-status-panel{flex:0 0 auto;width:clamp(180px,28vw,280px);display:flex;flex-direction:column;gap:clamp(8px,1.2vh,14px);justify-content:center}.device-test-mic-meter{display:flex;align-items:center;gap:8px}.device-test-mic-label{font-size:clamp(12px,1.4vw,14px);font-weight:600;min-width:40px}.device-test-mic-bar-bg{flex:1;height:8px;border-radius:4px;background:#e2e8f0;overflow:hidden}.device-test-mic-bar-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:4px;transition:width .1s ease}.device-row{display:flex;align-items:center;gap:8px;font-weight:700;font-size:clamp(13px,1.5vw,15px)}.device-row-icon{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:14px;flex-shrink:0;transition:background .3s,color .3s}.device-test-msg{font-size:clamp(12px,1.4vw,14px);font-weight:600;margin:0}.device-test-msg.ok{color:#16a34a}.device-test-msg.checking{color:#475467}.meeting-device-test-page .actions{margin-top:clamp(8px,1.2vh,16px);flex-shrink:0}@media(max-width:599px){.device-test-body{flex-direction:column;align-items:center}.device-test-video-wrapper{width:100%;max-width:320px;max-height:clamp(120px,28vh,200px)}.device-test-status-panel{width:100%}}@media(min-width:768px){.page{padding-top:clamp(10px,1.8vh,18px)}.box,.policy-card{padding:clamp(14px,2.4vh,28px) clamp(16px,2.5vw,36px)}.meeting-top .retro-shell{padding:clamp(16px,2.6vh,28px) clamp(18px,3vw,34px)}}
