@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500&family=Space+Grotesk:wght@400;600;700&display=swap";.rdp-root{--rdp-accent-color: blue;--rdp-accent-background-color: #f0f0ff;--rdp-day-height: 44px;--rdp-day-width: 44px;--rdp-day_button-border-radius: 100%;--rdp-day_button-border: 2px solid transparent;--rdp-day_button-height: 42px;--rdp-day_button-width: 42px;--rdp-selected-border: 2px solid var(--rdp-accent-color);--rdp-disabled-opacity: .5;--rdp-outside-opacity: .75;--rdp-today-color: var(--rdp-accent-color);--rdp-dropdown-gap: .5rem;--rdp-months-gap: 2rem;--rdp-nav_button-disabled-opacity: .5;--rdp-nav_button-height: 2.25rem;--rdp-nav_button-width: 2.25rem;--rdp-nav-height: 2.75rem;--rdp-range_middle-background-color: var(--rdp-accent-background-color);--rdp-range_middle-color: inherit;--rdp-range_start-color: white;--rdp-range_start-background: linear-gradient( var(--rdp-gradient-direction), transparent 50%, var(--rdp-range_middle-background-color) 50% );--rdp-range_start-date-background-color: var(--rdp-accent-color);--rdp-range_end-background: linear-gradient( var(--rdp-gradient-direction), var(--rdp-range_middle-background-color) 50%, transparent 50% );--rdp-range_end-color: white;--rdp-range_end-date-background-color: var(--rdp-accent-color);--rdp-week_number-border-radius: 100%;--rdp-week_number-border: 2px solid transparent;--rdp-week_number-height: var(--rdp-day-height);--rdp-week_number-opacity: .75;--rdp-week_number-width: var(--rdp-day-width);--rdp-weeknumber-text-align: center;--rdp-weekday-opacity: .75;--rdp-weekday-padding: .5rem 0rem;--rdp-weekday-text-align: center;--rdp-gradient-direction: 90deg;--rdp-animation_duration: .3s;--rdp-animation_timing: cubic-bezier(.4, 0, .2, 1)}.rdp-root[dir=rtl]{--rdp-gradient-direction: -90deg}.rdp-root[data-broadcast-calendar=true]{--rdp-outside-opacity: unset}.rdp-root{position:relative;box-sizing:border-box}.rdp-root *{box-sizing:border-box}.rdp-day{width:var(--rdp-day-width);height:var(--rdp-day-height);text-align:center}.rdp-day_button{background:none;padding:0;margin:0;cursor:pointer;font:inherit;color:inherit;justify-content:center;align-items:center;display:flex;width:var(--rdp-day_button-width);height:var(--rdp-day_button-height);border:var(--rdp-day_button-border);border-radius:var(--rdp-day_button-border-radius)}.rdp-day_button:disabled{cursor:revert}.rdp-caption_label{z-index:1;position:relative;display:inline-flex;align-items:center;white-space:nowrap;border:0}.rdp-dropdown:focus-visible~.rdp-caption_label{outline:5px auto Highlight;outline:5px auto -webkit-focus-ring-color}.rdp-button_next,.rdp-button_previous{border:none;background:none;padding:0;margin:0;cursor:pointer;font:inherit;color:inherit;-moz-appearance:none;-webkit-appearance:none;display:inline-flex;align-items:center;justify-content:center;position:relative;appearance:none;width:var(--rdp-nav_button-width);height:var(--rdp-nav_button-height)}.rdp-button_next:disabled,.rdp-button_next[aria-disabled=true],.rdp-button_previous:disabled,.rdp-button_previous[aria-disabled=true]{cursor:revert;opacity:var(--rdp-nav_button-disabled-opacity)}.rdp-chevron{display:inline-block;fill:var(--rdp-accent-color)}.rdp-root[dir=rtl] .rdp-nav .rdp-chevron{transform:rotate(180deg);transform-origin:50%}.rdp-dropdowns{position:relative;display:inline-flex;align-items:center;gap:var(--rdp-dropdown-gap)}.rdp-dropdown{z-index:2;opacity:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;position:absolute;inset-block-start:0;inset-block-end:0;inset-inline-start:0;width:100%;margin:0;padding:0;cursor:inherit;border:none;line-height:inherit}.rdp-dropdown_root{position:relative;display:inline-flex;align-items:center}.rdp-dropdown_root[data-disabled=true] .rdp-chevron{opacity:var(--rdp-disabled-opacity)}.rdp-month_caption{display:flex;align-content:center;height:var(--rdp-nav-height);font-weight:700;font-size:large}.rdp-root[data-nav-layout=around] .rdp-month,.rdp-root[data-nav-layout=after] .rdp-month{position:relative}.rdp-root[data-nav-layout=around] .rdp-month_caption{justify-content:center;margin-inline-start:var(--rdp-nav_button-width);margin-inline-end:var(--rdp-nav_button-width);position:relative}.rdp-root[data-nav-layout=around] .rdp-button_previous{position:absolute;inset-inline-start:0;top:0;height:var(--rdp-nav-height);display:inline-flex}.rdp-root[data-nav-layout=around] .rdp-button_next{position:absolute;inset-inline-end:0;top:0;height:var(--rdp-nav-height);display:inline-flex;justify-content:center}.rdp-months{position:relative;display:flex;flex-wrap:wrap;gap:var(--rdp-months-gap);max-width:fit-content}.rdp-month_grid{border-collapse:collapse}.rdp-nav{position:absolute;inset-block-start:0;inset-inline-end:0;display:flex;align-items:center;height:var(--rdp-nav-height)}.rdp-weekday{opacity:var(--rdp-weekday-opacity);padding:var(--rdp-weekday-padding);font-weight:500;font-size:smaller;text-align:var(--rdp-weekday-text-align);text-transform:var(--rdp-weekday-text-transform)}.rdp-week_number{opacity:var(--rdp-week_number-opacity);font-weight:400;font-size:small;height:var(--rdp-week_number-height);width:var(--rdp-week_number-width);border:var(--rdp-week_number-border);border-radius:var(--rdp-week_number-border-radius);text-align:var(--rdp-weeknumber-text-align)}.rdp-today:not(.rdp-outside){color:var(--rdp-today-color)}.rdp-selected{font-weight:700;font-size:large}.rdp-selected .rdp-day_button{border:var(--rdp-selected-border)}.rdp-outside{opacity:var(--rdp-outside-opacity)}.rdp-disabled:not(.rdp-selected){opacity:var(--rdp-disabled-opacity)}.rdp-hidden{visibility:hidden;color:var(--rdp-range_start-color)}.rdp-range_start{background:var(--rdp-range_start-background)}.rdp-range_start .rdp-day_button{background-color:var(--rdp-range_start-date-background-color);color:var(--rdp-range_start-color)}.rdp-range_middle{background-color:var(--rdp-range_middle-background-color)}.rdp-range_middle .rdp-day_button{border:unset;border-radius:unset;color:var(--rdp-range_middle-color)}.rdp-range_end{background:var(--rdp-range_end-background);color:var(--rdp-range_end-color)}.rdp-range_end .rdp-day_button{color:var(--rdp-range_start-color);background-color:var(--rdp-range_end-date-background-color)}.rdp-range_start.rdp-range_end{background:revert}.rdp-focusable{cursor:pointer}@keyframes rdp-slide_in_left{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes rdp-slide_in_right{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes rdp-slide_out_left{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes rdp-slide_out_right{0%{transform:translate(0)}to{transform:translate(100%)}}.rdp-weeks_before_enter{animation:rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_before_exit{animation:rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_after_enter{animation:rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_after_exit{animation:rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_after_enter{animation:rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_before_exit{animation:rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_before_enter{animation:rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_after_exit{animation:rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}@keyframes rdp-fade_in{0%{opacity:0}to{opacity:1}}@keyframes rdp-fade_out{0%{opacity:1}to{opacity:0}}.rdp-caption_after_enter{animation:rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_after_exit{animation:rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_before_enter{animation:rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_before_exit{animation:rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}:root{color-scheme:light;--ink: #12141f;--muted: #5d657f;--accent: #dc2626;--accent-dark: #991b1b;--panel: rgba(255, 255, 255, .82);--shadow: 0 20px 60px rgba(15, 20, 44, .2);--radius: 22px}*{box-sizing:border-box}body{margin:0;font-family:Space Grotesk,sans-serif;color:var(--ink);background:radial-gradient(circle at top left,#fff5f5,#f2f0ff 55%,#fdf2f2);min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,rgba(220,38,38,.18),transparent 55%),radial-gradient(circle at 80% 20%,rgba(220,38,38,.08),transparent 50%);z-index:-1}.app{max-width:1200px;margin:0 auto;padding:32px 24px 48px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:24px;margin-bottom:24px;position:relative;z-index:10}.brand{display:flex;align-items:center;gap:16px}.brand-mark{width:48px;height:48px;background:url(/hsc/logo.svg) center / contain no-repeat;border-radius:16px;box-shadow:0 8px 22px #0f172a1a}.brand h1{margin:0;font-size:28px;letter-spacing:-.02em}.brand p{margin:4px 0 0;color:var(--muted);font-family:IBM Plex Mono,monospace;font-size:12px;text-transform:uppercase;letter-spacing:.08em}.actions{display:flex;gap:12px}.layout{display:grid;grid-template-columns:minmax(280px,1.2fr) minmax(260px,.8fr);gap:24px}.panel{background:var(--panel);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.panel h2{margin:0 0 16px;font-size:20px}.camera-frame,.preview-frame{position:relative;border-radius:18px;overflow:hidden;background:#11131f;min-height:240px;display:flex;align-items:center;justify-content:center}.camera-frame video,.preview-frame img{width:100%;height:auto;display:block}.guide{position:absolute;top:12%;right:12%;bottom:12%;left:12%;border:2px dashed rgba(255,255,255,.7);border-radius:16px;pointer-events:none}.overlay-wrapper{position:relative;width:100%}.overlay-wrapper img,.overlay-wrapper canvas{width:100%;height:auto;display:block}.overlay-wrapper canvas{position:absolute;top:0;right:0;bottom:0;left:0}.panel-actions{margin-top:18px;display:flex;gap:12px;flex-wrap:wrap}button{border:none;border-radius:999px;padding:12px 18px;font-family:Space Grotesk,sans-serif;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}button.primary{background:var(--accent);color:#fff;box-shadow:0 12px 24px #dc26264d}button.secondary{background:#dc26261a;color:var(--accent);border:1px solid var(--accent)}button.ghost{background:#12141f14;color:var(--ink)}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 24px #12141f2e}button:disabled{opacity:.6;cursor:not-allowed}.editor-panel{display:flex;flex-direction:column}.hint{color:var(--muted);background:#12141f0f;padding:16px;border-radius:16px;font-size:14px}.editor-actions{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.block-list{display:flex;flex-direction:column;gap:12px;max-height:520px;overflow:auto;padding-right:4px}.block-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 8px 20px #12141f14}.block-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-family:IBM Plex Mono,monospace}.block-card input{width:100%;border:1px solid rgba(18,20,31,.12);border-radius:12px;padding:10px 12px;font-size:14px;margin-bottom:8px;font-family:Space Grotesk,sans-serif}.banner{padding:12px 16px;border-radius:14px;margin-bottom:18px;font-size:14px}.banner.error{background:#dc26262e;color:var(--accent-dark)}.hidden{display:none}@media (max-width: 900px){.layout{grid-template-columns:1fr}}.main-content{max-width:860px;margin:0 auto}.full-center{display:flex;align-items:center;justify-content:center;min-height:100vh}.tab-nav{display:flex;gap:4px;background:#12141f12;padding:4px;border-radius:999px}.tab{background:transparent;color:var(--muted);font-size:14px;padding:8px 20px;border-radius:999px;font-weight:600}.tab.active{background:#fff;color:var(--ink);box-shadow:0 4px 12px #12141f1f}.username-label{font-size:14px;color:var(--muted);font-family:IBM Plex Mono,monospace;align-self:center}.home-page{max-width:1120px;margin:0 auto;padding:28px 24px 40px}.home-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:56px}.home-auth-actions{display:flex;align-items:center;gap:10px}.home-hero{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:48px;margin-bottom:88px}.home-hero-text{text-align:left}.home-hero-badge{display:inline-flex;align-items:center;gap:8px;background:#dc26261a;color:var(--accent);font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:7px 16px;border-radius:999px;margin-bottom:22px;font-family:IBM Plex Mono,monospace;border:1px solid rgba(220,38,38,.16)}.home-hero-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 #dc262680;animation:heroPulse 2s infinite}@keyframes heroPulse{0%{box-shadow:0 0 #dc262680}70%{box-shadow:0 0 0 7px #dc262600}to{box-shadow:0 0 #dc262600}}.home-hero-title{font-size:clamp(34px,4.6vw,56px);font-weight:700;line-height:1.1;margin:0 0 20px;letter-spacing:-.025em}.home-hero-accent{background:linear-gradient(90deg,#dc2626,#f87171);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-hero-desc{font-size:17px;color:var(--muted);line-height:1.7;margin:0 0 32px;max-width:520px}.home-hero-cta{display:flex;gap:12px;flex-wrap:wrap}.home-cta-btn{padding:14px 28px;font-size:15px}.home-hero-stats{display:flex;align-items:center;gap:24px;margin-top:40px}.home-stat{display:flex;flex-direction:column}.home-stat strong{font-size:26px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}.home-stat span{font-size:12.5px;color:var(--muted);margin-top:2px}.home-stat-divider{width:1px;height:34px;background:#12141f1f}.home-hero-visual{display:flex;justify-content:center;perspective:1200px}.hero-card{position:relative;width:100%;max-width:380px;aspect-ratio:1.586 / 1;border-radius:22px;padding:22px;background:linear-gradient(150deg,#fff,#fff5f5 60%,#ffe4e4);box-shadow:0 30px 70px #991b1b47,inset 0 0 0 1px #fff9;overflow:hidden;transform:rotateY(-14deg) rotateX(6deg);transform-style:preserve-3d;animation:heroFloat 6s ease-in-out infinite}@keyframes heroFloat{0%,to{transform:rotateY(-14deg) rotateX(6deg) translateY(0)}50%{transform:rotateY(-10deg) rotateX(4deg) translateY(-12px)}}.hero-card-glow{position:absolute;top:-40%;right:-20%;width:70%;height:120%;background:radial-gradient(circle,rgba(220,38,38,.22),transparent 70%);filter:blur(10px)}.hero-card-top{display:flex;align-items:center;gap:10px;position:relative}.hero-card-logo{width:30px;height:30px;border-radius:8px;background:url(/hsc/logo.svg) center / contain no-repeat,var(--accent);flex-shrink:0}.hero-card-univ{font-size:10.5px;font-weight:700;letter-spacing:.04em;color:var(--accent-dark);font-family:IBM Plex Mono,monospace}.hero-card-body{display:flex;gap:16px;margin-top:22px;position:relative}.hero-card-photo{width:78px;height:96px;border-radius:10px;background:linear-gradient(160deg,#fecaca,#f87171);flex-shrink:0;box-shadow:inset 0 0 0 1px #991b1b1f}.hero-card-lines{display:flex;flex-direction:column;gap:11px;flex:1;padding-top:6px}.hero-line{height:9px;border-radius:999px;background:#991b1b29}.hero-line.w-70{width:70%}.hero-line.w-60{width:60%}.hero-line.w-50{width:50%}.hero-line.w-40{width:40%}.hero-card-qr{position:absolute;right:22px;bottom:20px;width:52px;height:52px;color:var(--accent-dark);opacity:.85}.hero-scanline{position:absolute;left:0;right:0;height:36px;background:linear-gradient(180deg,transparent,rgba(220,38,38,.35),transparent);box-shadow:0 0 18px #dc262680;animation:heroScan 3s ease-in-out infinite}@keyframes heroScan{0%,to{top:-10%;opacity:0}15%{opacity:1}50%{top:90%;opacity:1}85%{opacity:1}}.home-section-head{text-align:center;margin-bottom:32px}.home-section-title{font-size:clamp(24px,3vw,30px);font-weight:700;letter-spacing:-.02em;margin:0 0 8px}.home-section-sub{margin:0;color:var(--muted);font-size:15px}.home-features{margin-bottom:88px}.home-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.feature-card{position:relative;background:var(--panel);border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.6);overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);padding:1px;background:linear-gradient(135deg,rgba(220,38,38,.4),transparent 50%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .25s ease}.feature-card-btn{border-radius:var(--radius);text-align:left;display:flex;flex-direction:column;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.feature-card-btn:hover{transform:translateY(-4px);box-shadow:0 28px 70px #991b1b38}.feature-card-btn:hover:before{opacity:1}.feature-cta{margin-top:18px;font-size:13px;font-weight:700;color:var(--accent);letter-spacing:.02em;transition:transform .2s ease}.feature-card-btn:hover .feature-cta{transform:translate(4px)}.feature-icon{width:50px;height:50px;border-radius:15px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}.feature-icon-qr{background:linear-gradient(135deg,#dc262624,#f8717124);color:var(--accent)}.feature-icon-ocr{background:linear-gradient(135deg,#991b1b24,#dc26261a);color:var(--accent-dark)}.feature-card h3{margin:0 0 10px;font-size:17px}.feature-card p{margin:0;font-size:14px;color:var(--muted);line-height:1.65}.home-steps{margin-bottom:72px}.home-steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}.step-card{position:relative;background:#ffffff8c;border:1px solid rgba(220,38,38,.1);border-radius:18px;padding:28px 24px 24px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.step-num{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;font-weight:700;font-size:18px;margin-bottom:16px;box-shadow:0 8px 18px #dc26264d}.step-card h4{margin:0 0 8px;font-size:16px}.step-card p{margin:0;font-size:14px;color:var(--muted);line-height:1.6}.home-footer{display:flex;align-items:center;justify-content:center;gap:12px;padding-top:28px;border-top:1px solid rgba(18,20,31,.08)}.home-footer-mark{width:28px;height:28px;border-radius:9px;box-shadow:none}.home-footer p{margin:0;font-size:13px;color:var(--muted)}@media (max-width: 860px){.home-hero{grid-template-columns:1fr;gap:36px;text-align:center}.home-hero-text{text-align:center}.home-hero-desc{margin-left:auto;margin-right:auto}.home-hero-cta,.home-hero-stats{justify-content:center}.home-hero-visual{order:-1}.hero-card{max-width:320px}}.login-back{padding:6px 14px;font-size:13px;margin-bottom:16px;color:var(--muted)}.login-brand{justify-content:center;margin-bottom:4px}.login-subtitle{text-align:center;color:var(--muted);font-size:13px;font-family:IBM Plex Mono,monospace;text-transform:uppercase;letter-spacing:.06em;margin:0 0 28px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:600;color:var(--muted)}.field input{border:1.5px solid rgba(18,20,31,.14);border-radius:14px;padding:12px 16px;font-size:15px;font-family:Space Grotesk,sans-serif;background:#ffffffb3;outline:none;transition:border-color .2s}.field input:focus{border-color:var(--accent)}.auth-tabs{display:flex;background:#12141f12;border-radius:999px;padding:4px;margin-bottom:20px}.auth-tab{flex:1;background:transparent;color:var(--muted);font-size:14px;padding:8px 0;border-radius:999px;font-weight:600}.auth-tab.active{background:#fff;color:var(--accent);box-shadow:0 4px 12px #991b1b29}.ms-divider{display:flex;align-items:center;gap:12px;margin:14px 0 4px;color:var(--muted);font-size:12px}.ms-divider:before,.ms-divider:after{content:"";flex:1;height:1px;background:#12141f1f}.ms-login-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 14px;background:#fff;border:1px solid #d1d5db;border-radius:12px;color:#2f2f2f;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.ms-login-btn:hover:not(:disabled){background:#f7f7f7;border-color:#9ca3af;box-shadow:0 2px 8px #0f142c14}.ms-login-btn:disabled{opacity:.6;cursor:not-allowed}.auth-tab:not(.active):hover{color:var(--accent)}.login-success{color:#0d9b73;font-size:13px;background:#36d2a51f;padding:10px 14px;border-radius:12px;margin:0}.login-error{color:var(--accent-dark);font-size:13px;background:#dc26261a;padding:10px 14px;border-radius:12px;margin:0}.auth-divider{display:flex;align-items:center;gap:12px;color:#94a3b8;font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin:18px 0 12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.google-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 14px;font-size:14px;font-weight:500;color:#1f2937;background:#fff;border:1px solid #d1d5db;border-radius:12px;cursor:pointer;transition:background .15s,box-shadow .15s,border-color .15s}.google-btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af;box-shadow:0 1px 3px #0000000f}.google-btn:disabled{opacity:.6;cursor:not-allowed}.full-width{width:100%;padding:14px;font-size:15px}.scanner-page{display:flex;flex-direction:column;gap:20px;padding:8px 0}.scanner-head{text-align:center;margin-bottom:2px}.scanner-mode-chip{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:6px 14px;border-radius:999px;font-family:IBM Plex Mono,monospace;background:#dc26261a;color:var(--accent);border:1px solid rgba(220,38,38,.16)}.scanner-mode-chip.ocr{background:#991b1b1a;color:var(--accent-dark);border-color:#991b1b2e}.scanner-mode-dot{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse 1.4s ease-in-out infinite}.scanner-head-title{font-size:clamp(22px,3vw,28px);font-weight:700;letter-spacing:-.02em;margin:12px 0 6px}.scanner-head-sub{color:var(--muted);font-size:14.5px;line-height:1.6;max-width:520px;margin:0 auto}.engine-toggle{display:inline-flex;gap:4px;margin-top:16px;padding:4px;background:#12141f0f;border-radius:999px}.engine-tab{background:transparent;color:var(--muted);font-size:13px;font-weight:600;padding:7px 18px;border-radius:999px;transition:all .18s ease}.engine-tab:not(.active):hover:not(:disabled){color:var(--accent)}.engine-tab.active{background:#fff;color:var(--accent);box-shadow:0 4px 12px #991b1b29}.engine-tab.active.gemini{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;box-shadow:0 6px 16px #dc262652}.webcam-wrapper{position:relative;border-radius:22px;overflow:hidden;background:#11131f;aspect-ratio:4 / 3;max-height:480px;display:flex;align-items:center;justify-content:center;box-shadow:0 24px 60px #991b1b38;border:1px solid rgba(220,38,38,.2);isolation:isolate;z-index:0}.webcam-wrapper:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:22px;pointer-events:none;box-shadow:inset 0 0 0 1px #ffffff14,inset 0 0 80px #dc26261f;z-index:11}.webcam-video{width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;right:0;bottom:0;left:0}.card-guide{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:68%;aspect-ratio:85.6 / 54;pointer-events:none}.guide-corner{position:absolute;width:26px;height:26px;border-color:#f87171;border-style:solid;filter:drop-shadow(0 0 4px rgba(220,38,38,.7))}.guide-corner.tl{top:0;left:0;border-width:3px 0 0 3px;border-radius:6px 0 0}.guide-corner.tr{top:0;right:0;border-width:3px 3px 0 0;border-radius:0 6px 0 0}.guide-corner.bl{bottom:0;left:0;border-width:0 0 3px 3px;border-radius:0 0 0 6px}.guide-corner.br{bottom:0;right:0;border-width:0 3px 3px 0;border-radius:0 0 6px}.guide-label{position:absolute;bottom:-30px;left:50%;transform:translate(-50%);color:#ffffffeb;background:#dc2626d9;font-size:11px;font-weight:600;white-space:nowrap;letter-spacing:.04em;padding:4px 12px;border-radius:999px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#12141f8c;display:flex;align-items:center;justify-content:center;gap:10px;color:#fff;font-weight:600;font-size:15px}.scan-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.qr-laser{position:absolute;left:0;right:0;height:2px;background:linear-gradient(to right,transparent 0%,rgba(255,60,60,.15) 15%,rgba(255,60,60,.9) 50%,rgba(255,60,60,.15) 85%,transparent 100%);box-shadow:0 0 6px 2px #ff3c3c80;animation:laser-sweep 2s ease-in-out infinite;pointer-events:none;z-index:10}@keyframes laser-sweep{0%{top:10%}50%{top:88%}to{top:10%}}.auto-badge{position:absolute;top:12px;right:12px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;letter-spacing:.08em;padding:3px 10px;border-radius:999px;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.scanner-controls{display:flex;gap:10px;flex-wrap:wrap}button.active-btn{background:var(--accent-dark)}.scan-result-card{background:var(--panel);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.scan-result-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.scan-result-id{font-family:IBM Plex Mono,monospace;font-size:12px;color:var(--muted)}.scan-result-body{display:flex;gap:16px;align-items:flex-start}.warped-thumb{width:120px;height:auto;border-radius:10px;object-fit:cover;flex-shrink:0;border:1.5px solid rgba(18,20,31,.1)}.student-info{flex:1;display:flex;flex-direction:column;gap:6px}.student-avatar{width:72px;height:90px;object-fit:cover;border-radius:6px;border:2px solid rgba(18,20,31,.12);align-self:flex-start;margin-bottom:4px}.avatar-preview{width:40px;height:40px;object-fit:cover;border-radius:50%;border:2px solid var(--accent, #5c6bc0);vertical-align:middle}.qr-raw{font-family:IBM Plex Mono,monospace;font-size:11px;word-break:break-all}.qr-link{color:#2563eb;text-decoration:underline;word-break:break-all}.qr-link:hover{color:#1d4ed8}.qr-cam-overlay{position:absolute;left:50%;bottom:16px;transform:translate(-50%);width:min(92%,460px);padding:14px 16px;background:#0f172ae0;color:#f8fafc;border-radius:14px;border:1px solid rgba(107,99,99,.12);box-shadow:0 12px 32px #5d575759;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5;animation:qr-cam-pop .22s ease-out}@keyframes qr-cam-pop{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.qr-cam-overlay-title{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#fca5a5;margin-bottom:6px}.qr-cam-overlay-link{display:block;font-family:IBM Plex Mono,monospace;font-size:12px;color:#e2e8f0;text-decoration:none;word-break:break-all;max-height:4.5em;overflow:hidden;margin-bottom:10px}.qr-cam-overlay-link:hover{color:#fff;text-decoration:underline}.qr-cam-overlay-actions{display:flex;gap:8px}.qr-cam-btn{flex:1;padding:7px 12px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#f8fafc;border-radius:8px;font-size:13px;text-align:center;cursor:pointer;text-decoration:none;transition:background .12s ease}.qr-cam-btn:hover{background:#ffffff29}.qr-cam-btn.primary{background:var(--accent);border-color:var(--accent)}.qr-cam-btn.primary:hover{background:var(--accent-dark)}.match-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600}.match-ok{background:#dcfce7;color:#16a34a}.match-fail{background:#fee2e2;color:#dc2626}.ocr-steps{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px 20px;margin:16px 0}.ocr-steps-title{font-size:13px;font-weight:600;color:#64748b;margin:0 0 12px;text-transform:uppercase;letter-spacing:.05em}.ocr-step{display:flex;align-items:center;gap:10px;padding:6px 0;transition:color .3s}.step-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;transition:background .3s}.step-name{flex:1;font-size:13.5px;transition:color .3s}.step-badge{font-size:11px;color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.ocr-step-card{background:#fff;border:1px solid #e2e8f0;border-left:4px solid #9ca3af;border-radius:12px;padding:12px 14px;margin-bottom:10px;opacity:0;transform:translateY(6px);transition:opacity .35s ease,transform .35s ease,border-left-color .35s ease}.ocr-step-card.visible{opacity:1;transform:translateY(0)}.ocr-step-header{display:flex;align-items:center;gap:10px}.ocr-step-header .step-name{font-weight:600;font-size:14px}.ocr-step-desc{margin:8px 0 10px 20px;font-size:13px;color:#475569;line-height:1.5}.ocr-step-image{display:block;width:100%;max-height:420px;object-fit:contain;background:#0f172a;border-radius:8px;margin-top:4px}.manual-lookup{background:linear-gradient(135deg,#fef2f2e6,#ffffffd9);border:1px solid rgba(220,38,38,.14);border-radius:18px;padding:22px 24px;margin:4px 0;box-shadow:0 10px 28px #991b1b14}.manual-lookup-label{font-size:15px;font-weight:700;color:var(--accent-dark);margin:0 0 14px;display:flex;align-items:center;gap:8px}.manual-lookup-label:before{content:"";width:4px;height:16px;border-radius:999px;background:var(--accent)}.manual-lookup-row{display:flex;gap:10px}.mssv-input-wrapper{position:relative;flex:1}.mssv-input-display{position:absolute;top:0;right:0;bottom:0;left:0;padding:12px 16px;font-size:18px;font-family:IBM Plex Mono,monospace;font-weight:600;letter-spacing:.04em;pointer-events:none;white-space:pre;overflow:hidden;display:flex;align-items:center;border-radius:10px}.mssv-input{width:100%;padding:12px 16px;border:1.5px solid #cbd5e1;border-radius:10px;font-size:18px;outline:none;transition:border-color .2s;background:#fff}.mssv-input-ghost{position:relative;color:transparent;caret-color:#12141f;font-family:IBM Plex Mono,monospace;font-weight:600;letter-spacing:.04em;background:transparent}.mssv-input-ghost::placeholder{color:#9ca3af;font-family:Space Grotesk,sans-serif;font-weight:400;letter-spacing:normal}.mssv-input:focus{border-color:#dc2626}.manual-lookup-row button.primary{padding:12px 22px;font-size:15px;white-space:nowrap}.lookup-error{font-size:13px;color:#dc2626;margin:8px 0 0}.history-section{margin-top:32px}.history-section-title{font-size:18px;font-weight:700;margin:0 0 16px;display:flex;align-items:center;gap:10px}.history-section-title:before{content:"";width:5px;height:20px;border-radius:999px;background:linear-gradient(180deg,var(--accent),var(--accent-dark))}.dashboard-page{padding:8px 0}.dashboard-page h2{margin:0 0 20px;font-size:22px}.table-wrapper{background:var(--panel);border-radius:var(--radius);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow-x:auto;-webkit-overflow-scrolling:touch}.history-table{width:100%;border-collapse:collapse;font-size:14px;min-width:480px}.history-table th{text-align:left;padding:14px 20px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border-bottom:1.5px solid rgba(18,20,31,.08)}.history-row{cursor:pointer;transition:background .15s}.history-row:hover{background:#dc26260f}.history-row td{padding:14px 20px;border-bottom:1px solid rgba(18,20,31,.06)}.row-num{color:var(--muted);font-family:IBM Plex Mono,monospace;width:40px}.row-time{color:var(--muted);font-size:13px}button.ghost.small{padding:6px 14px;font-size:13px}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.badge.qr{background:#dc26261f;color:#991b1b}.badge.ocr{background:#991b1b29;color:var(--accent-dark)}.badge.lookup{background:#f9731624;color:#c2410c}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c0f1e8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.modal-card{background:#fff;border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;position:relative;display:flex;flex-direction:column;gap:18px}.modal-close{position:absolute;top:16px;right:16px;background:#12141f12;border-radius:50%;width:32px;height:32px;padding:0;font-size:14px;display:flex;align-items:center;justify-content:center}.modal-header h3{margin:0 0 6px;font-size:18px}.modal-meta{display:flex;align-items:center;gap:10px}.modal-image{width:100%;border-radius:14px;border:1.5px solid rgba(18,20,31,.1);object-fit:contain;max-height:200px}.info-grid{display:flex;flex-direction:column;gap:10px;background:#12141f0a;border-radius:16px;padding:16px}.info-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:14px}.info-row span{color:var(--muted);font-size:13px;flex-shrink:0}.info-row strong{text-align:right;word-break:break-word}.raw-section{background:#12141f0d;border-radius:14px;padding:14px}.face-match{margin-top:12px;padding:12px 14px;background:#12141f0a;border-left:4px solid #6b7280;border-radius:10px}.face-match-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.face-match-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;color:#fff;font-size:13px;font-weight:700;flex-shrink:0}.face-match-label{font-size:14px;font-weight:700}.face-match-conf{font-size:12px;font-weight:600;color:var(--muted);margin-left:auto}.face-match-note{margin:6px 0 0;font-size:13px;line-height:1.45;color:var(--muted)}.raw-label{font-size:12px;font-weight:600;color:var(--muted);margin:0 0 8px;text-transform:uppercase;letter-spacing:.05em}.raw-pre{margin:0;font-family:IBM Plex Mono,monospace;font-size:12px;word-break:break-all;white-space:pre-wrap;color:var(--ink)}.teams-send-to{margin:0 0 8px;font-size:13px;color:var(--muted)}.teams-send-to strong{color:var(--ink);word-break:break-all}.teams-locked-note{margin:0 0 10px;padding:8px 10px;font-size:12.5px;line-height:1.5;color:#92400e;background:#f59e0b1f;border:1px solid rgba(245,158,11,.3);border-radius:8px}.teams-locked-note strong{color:#b45309}.teams-msg{width:100%;box-sizing:border-box;resize:vertical;padding:10px 12px;border:1px solid rgba(18,20,31,.16);border-radius:10px;font:inherit;font-size:13px;line-height:1.5;color:var(--ink);background:#fff}.teams-msg:focus{outline:none;border-color:var(--accent)}.teams-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.teams-btn{padding:9px 16px;border:none;border-radius:10px;background:#4b53bc;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s ease,opacity .12s ease}.teams-btn:hover{background:#3a41a0}.teams-btn.email-btn{background:var(--accent)}.teams-btn.email-btn:hover{background:var(--accent-dark)}.teams-btn:disabled{opacity:.5;cursor:default}@media (max-width: 640px){.app{padding:16px 14px 40px}.topbar{flex-wrap:wrap;gap:10px;margin-bottom:14px}.brand h1{font-size:22px}.brand-mark{width:38px;height:38px;border-radius:12px}.tab-nav{order:3;width:100%;justify-content:stretch}.tab-nav .tab{flex:1;text-align:center;font-size:13px;padding:8px 6px}.actions{gap:8px}.actions button{padding:8px 14px;font-size:13px}.username-label{font-size:13px}.scanner-page{gap:14px}.webcam-wrapper{border-radius:14px;max-height:none;width:100%}.scanner-controls{flex-direction:row;gap:8px}.scanner-controls button{flex:1;font-size:13px;padding:10px 12px}.manual-lookup{padding:16px 14px;border-radius:12px;margin:8px 0}.manual-lookup-label{font-size:14px;margin-bottom:10px}.mssv-input-display,.mssv-input{font-size:15px;padding:10px 12px}.mssv-input-display{padding:10px 12px}.manual-lookup-row button.primary{padding:10px 14px;font-size:14px}.scan-result-card{padding:14px;border-radius:16px}.scan-result-body{flex-direction:column;gap:10px}.warped-thumb{width:100%;max-height:180px;object-fit:contain}.student-info{gap:4px}.info-row{font-size:13px;gap:6px}.info-row span{font-size:12px}.history-section{margin-top:20px}.history-section-title{font-size:16px}.history-table{font-size:13px}.history-table th,.history-row td{padding:10px 12px}.modal-overlay{padding:0;align-items:flex-end}.modal-card{max-width:100%;width:100%;max-height:92vh;border-radius:24px 24px 0 0;padding:20px 16px 32px}.ocr-steps{padding:12px 14px}.step-name{font-size:13px}}.rdp-root{--rdp-accent-color: var(--accent);--rdp-day-height: 36px;--rdp-day-width: 36px}.rdp-day_button{border-radius:10px}.rdp-selected .rdp-day_button{background:var(--accent);color:#fff;border-radius:10px}.rdp-today:not(.rdp-selected) .rdp-day_button{color:var(--accent);font-weight:700}.rdp-chevron{fill:var(--ink)}.rdp-month_grid{min-height:224px}.rdp-month{min-height:300px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(900px 600px at -10% -10%,rgba(220,38,38,.18),transparent 60%),radial-gradient(800px 500px at 110% 110%,rgba(255,111,60,.18),transparent 55%),linear-gradient(180deg,#fafbfc,#eef0f4);position:relative;overflow:hidden}.login-page:before,.login-page:after{content:"";position:absolute;border-radius:50%;filter:blur(60px);z-index:0;pointer-events:none}.login-page:before{width:320px;height:320px;background:#dc262640;top:-80px;left:-80px}.login-page:after{width:380px;height:380px;background:#ffb05a40;bottom:-120px;right:-100px}.login-shell{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr 1fr;gap:32px;width:100%;max-width:1080px}@media (max-width: 880px){.login-shell{grid-template-columns:1fr;gap:16px}.login-hero{display:none}}.login-hero{padding:40px;display:flex;flex-direction:column;justify-content:space-between;min-height:520px;color:#fff;border-radius:28px;background:linear-gradient(135deg,#b91c1c,#7f1d1d);box-shadow:0 24px 60px #7f1d1d59;position:relative;overflow:hidden}.login-hero-slides{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.login-hero-slide{position:absolute;top:0;right:0;bottom:0;left:0;background-position:center;background-size:cover;background-repeat:no-repeat;opacity:0;will-change:transform,opacity;animation:heroSlideShow 24s infinite}.login-hero-slide:nth-child(1){animation-delay:0s}.login-hero-slide:nth-child(2){animation-delay:-18s}.login-hero-slide:nth-child(3){animation-delay:-12s}.login-hero-slide:nth-child(4){animation-delay:-6s}@keyframes heroSlideShow{0%{opacity:0;transform:translate(70px) scale(1.06)}4%{opacity:1;transform:translate(0) scale(1.04)}25%{opacity:1;transform:translate(0) scale(1)}29%{opacity:0;transform:translate(-70px) scale(1.04)}to{opacity:0;transform:translate(-70px) scale(1.06)}}@media (prefers-reduced-motion: reduce){.login-hero-slide{animation-duration:0s}.login-hero-slide:nth-child(1){opacity:1}}.login-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:linear-gradient(180deg,#7f1d1d33,#7f1d1d9e 58%,#7f1d1df2);pointer-events:none}.login-hero-top,.login-hero-bottom{position:relative;z-index:3}.login-hero-badge{display:inline-flex;align-items:center;gap:8px;background:#ffffff29;border:1px solid rgba(255,255,255,.28);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:7px 14px;border-radius:999px;font-family:IBM Plex Mono,monospace}.login-hero-badge-dot{width:7px;height:7px;border-radius:50%;background:#fff;box-shadow:0 0 #fff9;animation:heroPulse 2s infinite}.login-hero h2{font-family:Space Grotesk,system-ui,sans-serif;font-size:34px;font-weight:700;line-height:1.12;margin:0;letter-spacing:-.02em;text-shadow:0 2px 16px rgba(0,0,0,.4)}.login-hero p{color:#ffffffeb;font-size:14px;line-height:1.6;margin:10px 0 18px;text-shadow:0 1px 8px rgba(0,0,0,.35)}.login-card{background:#ffffffc7;border:1px solid rgba(255,255,255,.55);border-radius:28px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 24px 60px #0f142c1f;padding:32px;display:flex;flex-direction:column;min-height:720px;max-height:calc(100vh - 48px);overflow:hidden}.field-floating{position:relative;margin-bottom:14px}.field-floating input,.field-floating .fake-input{width:100%;padding:22px 14px 8px;border:1px solid #d1d5db;border-radius:12px;font-size:15px;background:#fff;outline:none;transition:border-color .18s,box-shadow .18s;box-sizing:border-box;font-family:inherit;color:var(--ink)}.field-floating input:focus{border-color:var(--accent);box-shadow:0 0 0 4px #dc262624}.field-floating>label{position:absolute;left:14px;top:16px;font-size:14px;color:#6b7280;pointer-events:none;transition:all .18s ease;background:transparent}.field-floating input:focus+label,.field-floating input:not(:placeholder-shown)+label,.field-floating.has-value>label{top:6px;font-size:11px;color:var(--accent);font-weight:600;letter-spacing:.02em}.field-floating.is-invalid input{border-color:#ef4444;box-shadow:0 0 0 4px #ef44441f}.field-floating.is-valid input{border-color:#10b981}.field-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center}.field-icon-btn{background:none;border:none;padding:6px;border-radius:6px;cursor:pointer;color:#6b7280;transition:color .15s,background .15s}.field-icon-btn:hover{color:var(--accent);background:#dc26260f}.field-icon-valid{color:#10b981}.field-icon-invalid{color:#ef4444}.field-hint{font-size:11px;color:#6b7280;margin-top:4px;margin-left:2px}.field-hint.err{color:#ef4444}.field-hint.warn{color:#f59e0b;display:inline-flex;align-items:center;gap:6px}.auth-pane{animation:pane-in .22s ease-out}@keyframes pane-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#111827;color:#fff;padding:12px 20px;border-radius:999px;box-shadow:0 12px 32px #00000038;font-size:14px;z-index:2000;animation:toast-in .25s ease-out;display:inline-flex;align-items:center;gap:10px;max-width:calc(100vw - 32px)}.toast.success{background:#059669}.toast.error{background:#dc2626}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.btn-spinner{width:16px;height:16px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block;margin-right:8px;vertical-align:-3px}@keyframes spin{to{transform:rotate(360deg)}}.modal-backdrop{animation:backdrop-in .18s ease-out}.modal-pop{animation:pop-in .22s cubic-bezier(.2,1.2,.3,1)}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes pop-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.94)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.rdp-day_button:hover:not([disabled]):not(.rdp-selected){background:#dc26261a;border-radius:10px;color:var(--accent)}.rdp-dropdown{border-radius:8px;border:1px solid #d1d5db;padding:4px 6px;font-size:13px;background:#fff}.rdp-button_previous,.rdp-button_next{border-radius:10px}.rdp-button_previous:hover,.rdp-button_next:hover{background:#dc262614;color:var(--accent)}.login-hero{height:720px;min-height:720px}@media (max-width: 880px){.login-card{height:auto;min-height:720px}.login-hero{height:auto}}.login-form{flex:1;min-height:0;display:flex;flex-direction:column;gap:12px;overflow-y:auto;overflow-x:visible;padding-right:4px;margin-right:-4px}.login-form>button[type=submit]{margin-top:auto;flex-shrink:0}.field-floating{margin-bottom:0}.field-reserve{min-height:18px}.auth-subtabs{background:#dc26260d;padding:4px;margin-top:-10px;margin-bottom:18px;border:1px solid rgba(220,38,38,.08)}.auth-subtabs .auth-tab{font-size:13px;padding:7px 0;font-weight:500;transition:all .18s ease}.auth-subtabs .auth-tab.active{background:var(--accent);color:#fff;box-shadow:0 4px 14px #dc26264d;font-weight:600}.auth-subtabs .auth-tab:not(.active):hover{color:var(--accent)}.login-subtitle{margin:0 0 22px}.cam-select-wrap{position:absolute;right:12px;bottom:12px;z-index:6;display:inline-flex;align-items:center;gap:6px;padding:6px 10px 6px 12px;background:#0000008c;border:1px solid rgba(255,255,255,.18);border-radius:999px;color:#fff;font-size:12px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);max-width:calc(100% - 24px)}.cam-select-wrap svg{flex-shrink:0;opacity:.9}.cam-select{background:transparent;color:#fff;border:none;outline:none;font-size:13px;font-family:inherit;padding:0 4px;max-width:200px;text-overflow:ellipsis;cursor:pointer}.cam-select option{color:#111;background:#fff}.profile-page{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.profile-back{align-self:flex-start;font-size:13px;padding:8px 16px}.profile-header{position:relative;display:flex;gap:26px;align-items:flex-end;background:#ffffffe0;border:1px solid rgba(15,23,42,.08);border-radius:24px;padding:22px 26px 24px;box-shadow:0 16px 40px #991b1b1f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden}.profile-cover{position:absolute;top:0;left:0;right:0;height:96px;background:linear-gradient(120deg,var(--accent) 0%,var(--accent-dark) 60%,#7f1d1d 100%)}.profile-cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 85% 0%,rgba(255,255,255,.25),transparent 55%)}.profile-avatar-wrap{position:relative;display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:36px}.profile-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid #fff;box-shadow:0 10px 28px #991b1b47;background:#f1f5f9}.profile-avatar-placeholder{display:flex;align-items:center;justify-content:center;font-size:46px;font-weight:700;color:#fff;background:linear-gradient(135deg,#f87171 0%,var(--accent-dark) 100%)}.profile-avatar-actions{display:flex;gap:6px}.profile-avatar-actions button{font-size:12px;padding:6px 12px}.profile-header-info{flex:1;position:relative;padding-bottom:4px}.profile-header-info h2{margin:0 0 8px;font-size:25px;letter-spacing:-.02em}.profile-chip{display:inline-flex;align-items:center;gap:6px;background:#dc26261a;color:var(--accent);font-size:12px;font-weight:600;padding:5px 12px;border-radius:999px;border:1px solid rgba(220,38,38,.16);margin-bottom:12px}.profile-meta-list{display:flex;flex-direction:column;gap:5px}.profile-meta{color:var(--muted);font-size:13px;font-family:IBM Plex Mono,monospace}.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px}.stat-card{position:relative;background:#ffffffe6;border:1px solid rgba(15,23,42,.07);border-radius:18px;padding:18px 16px;text-align:left;box-shadow:0 8px 22px #0f172a0d;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease}.stat-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--tint)}.stat-card:hover{transform:translateY(-3px);box-shadow:0 16px 32px color-mix(in srgb,var(--tint) 22%,transparent)}.stat-icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;margin-bottom:12px;color:var(--tint);background:color-mix(in srgb,var(--tint) 12%,transparent)}.stat-value{font-size:30px;font-weight:700;font-family:Space Grotesk,sans-serif;color:var(--ink);line-height:1}.stat-label{margin-top:6px;font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-family:IBM Plex Mono,monospace}.profile-section{background:#ffffffe0;border:1px solid rgba(15,23,42,.08);border-radius:22px;padding:24px;box-shadow:0 10px 26px #0f172a0f}.profile-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.profile-section-header h3{margin:0;font-size:17px}.profile-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media (max-width: 640px){.profile-info-grid{grid-template-columns:1fr}.profile-header{flex-direction:column;align-items:center;text-align:center}.profile-header-info{padding-bottom:0}.profile-chip{margin-left:auto;margin-right:auto}.profile-meta-list{align-items:center}}.profile-info-row{display:flex;flex-direction:column;background:#0f172a08;border-radius:12px;padding:10px 14px}.profile-info-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-family:IBM Plex Mono,monospace}.profile-info-value{font-size:15px;color:var(--ink);font-weight:500;margin-top:4px}.profile-info-value.muted{color:var(--muted)}.profile-edit-form{display:flex;flex-direction:column;gap:12px}.profile-edit-form .field{display:flex;flex-direction:column;gap:6px}.profile-edit-form label{font-size:12px;color:var(--muted)}.profile-edit-form input{padding:10px 12px;border:1px solid #d1d5db;border-radius:10px;font-size:14px;font-family:inherit;outline:none}.profile-edit-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #dc26261f}.username-label.clickable{cursor:pointer;transition:color .15s}.username-label.clickable:hover{color:var(--accent)}
