:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fbff;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{min-width:320px;min-height:100vh;margin:0}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.65}a{color:inherit;text-decoration:none}#root{min-height:100vh}.app-shell{background:linear-gradient(135deg, #38bdf81a, #c084fc1f), var(--bg-color);grid-template-columns:260px minmax(0,1fr);min-height:100vh;display:grid}.app-sidebar{color:#e2e8f0;background:linear-gradient(#4f46e5f5,#0ea5e9db);border-right:1px solid #ffffff29;flex-direction:column;height:100vh;padding:24px;display:flex;position:sticky;top:0;box-shadow:18px 0 42px #4f46e51f}.admin-sidebar{background:linear-gradient(#7c3aedf5,#f59e0bd1)}.admin-sidebar .app-brand-mark{background:var(--warm-gradient)}.app-brand{align-items:center;gap:12px;margin-bottom:34px;display:flex}.app-brand-mark{color:#fff;background:#ffffff38;border-radius:14px;place-items:center;width:42px;height:42px;font-weight:900;display:grid;box-shadow:0 12px 24px #0f172a29}.app-brand strong,.app-brand small{display:block}.app-brand small{color:#94a3b8;font-size:12px}.app-nav{gap:8px;display:grid}.app-nav a{border-radius:var(--border-radius);color:#cbd5e1;padding:12px 14px;font-weight:700;transition:transform .24s,background .24s,color .24s}.app-nav a.active,.app-nav a:hover{color:#fff;background:#fff3;transform:translate(3px)}.app-user{border-top:1px solid #ffffff1f;gap:12px;margin-top:auto;padding-top:18px;display:grid}.app-user span{color:#fff;font-size:14px;font-weight:700}.app-user button{border-radius:var(--border-radius);color:#fff;background:#ffffff2e;border:0;padding:10px 12px;font-weight:700;transition:transform .25s,background .25s}.app-user button:hover{background:#ffffff47;transform:translateY(-2px)scale(1.03)}.app-main{min-width:0;padding:32px}@media (width<=860px){.app-shell{grid-template-columns:1fr}.app-sidebar{height:auto;position:static}.app-main{padding:20px}}.chatbot{z-index:50;position:fixed;bottom:22px;right:22px}.chatbot-toggle{background:var(--primary-color);color:#fff;width:56px;height:56px;box-shadow:var(--box-shadow);border:0;border-radius:50%;font-weight:900}.chatbot-panel{border:1px solid var(--border-color);border-radius:var(--border-radius);width:min(360px,100vw - 32px);height:460px;box-shadow:var(--box-shadow);background:#fff;margin-bottom:12px;display:grid;overflow:hidden}.chatbot-panel header,.chatbot-panel form{border-bottom:1px solid var(--border-color);align-items:center;gap:10px;padding:12px;display:flex}.chatbot-panel header{color:#fff;background:#0f172a;justify-content:space-between}.chatbot-panel header button,.chatbot-panel form button{border-radius:var(--border-radius);background:var(--primary-color);color:#fff;border:0;padding:9px 12px;font-weight:800}.chatbot-messages{flex-direction:column;gap:10px;padding:14px;display:flex;overflow-y:auto}.chatbot-message{border-radius:var(--border-radius);max-width:82%;padding:10px 12px;font-size:14px;line-height:1.4}.chatbot-message.user{background:var(--primary-color);color:#fff;align-self:flex-end}.chatbot-message.assistant{color:var(--text-color);background:#f1f5f9;align-self:flex-start}.chatbot-panel form{border-top:1px solid var(--border-color);border-bottom:0}.chatbot-panel input{border:1px solid var(--border-color);border-radius:var(--border-radius);flex:1;min-width:0;padding:10px 12px}.public-layout{background:linear-gradient(150deg,#ffffffe6 0%,#f0f9ffdb 42%,#faf5ffe0 100%),linear-gradient(90deg,#6366f10d 1px,#0000 1px) 0 0/56px 56px,linear-gradient(#0ea5e90a 1px,#0000 1px) 0 0/56px 56px;min-height:100vh;position:relative;overflow-x:hidden}.public-layout:before{pointer-events:none;content:"";background:linear-gradient(115deg,#38bdf814,#0000 34%),linear-gradient(245deg,#facc1514,#0000 32%),linear-gradient(#0000 0%,#ffffff9e 72%);position:fixed;inset:0}.public-header{z-index:10;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffc7;border-bottom:1px solid #94a3b838;justify-content:space-between;align-items:center;padding:14px 32px;display:flex;position:sticky;top:0;box-shadow:0 10px 30px #4f46e514}.public-brand{align-items:center;gap:10px;font-weight:900;display:inline-flex}.public-brand span{background:var(--brand-gradient);color:#fff;border-radius:8px;place-items:center;width:34px;height:34px;display:grid;box-shadow:0 10px 22px #4f46e538}.public-header nav{gap:10px;display:flex}.public-header nav a,.public-nav-button{border-radius:var(--border-radius);color:var(--text-muted);background:0 0;border:0;padding:9px 12px;font-weight:800}.public-header nav a.active,.public-header nav a:hover,.public-nav-button:hover{background:var(--primary-soft);color:var(--primary-color)}@media (width<=760px){.public-header{flex-direction:column;align-items:flex-start;gap:12px}.public-header nav{flex-wrap:wrap}}.state,.error-state{border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--surface-color);color:var(--text-muted);text-align:center;box-shadow:var(--box-shadow);place-items:center;gap:12px;padding:28px;animation:.35s both fadeSlideIn;display:grid}.state-fullscreen{min-height:100vh}.state-spinner{border:4px solid #dbe3ef;border-top-color:var(--primary-color);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.error-state{color:#991b1b;background:#fff1f2eb;border-color:#dc262640;margin-bottom:18px}.error-state strong{color:#7f1d1d}.error-state button,.pagination button{border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-color);background:#ffffffd6;padding:9px 14px;font-weight:700;transition:transform .25s,box-shadow .25s,border-color .25s}.error-state button:hover:not(:disabled),.pagination button:hover:not(:disabled){box-shadow:var(--box-shadow);border-color:#6366f16b;transform:translateY(-2px)scale(1.03)}.pagination{color:var(--text-muted);justify-content:flex-end;align-items:center;gap:12px;margin-top:18px;font-weight:700;display:flex}.qr-card{border-radius:var(--border-radius);background:#fff;border:10px solid #fff;grid-template-columns:repeat(7,18px);gap:4px;width:max-content;display:grid;box-shadow:0 12px 30px #0f172a24}.qr-card span{background:#f1f5f9;border-radius:3px;width:18px;height:18px}.qr-card .qr-cell-active{background:#0f172a}@keyframes spin{to{transform:rotate(360deg)}}.admin-page{max-width:1280px;margin:0 auto}.admin-grid{grid-template-columns:340px minmax(0,1fr);align-items:start;gap:22px;display:grid}.admin-form,.admin-panel{border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--box-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe0;animation:.35s both fadeSlideIn}.admin-form{gap:14px;padding:20px;display:grid;position:sticky;top:24px}.admin-panel{overflow:hidden}.admin-row{border-bottom:1px solid var(--border-color);grid-template-columns:minmax(160px,1fr) minmax(120px,1fr) repeat(2,auto);align-items:center;gap:12px;padding:14px 16px;transition:transform .24s,background .24s;display:grid}.admin-row:hover{background:#eef2ffbd;transform:translate(3px)}.admin-row:last-child{border-bottom:0}.admin-row span{color:var(--text-muted)}.admin-row button{border:1px solid var(--border-color);border-radius:var(--border-radius);background:#ffffffdb;padding:8px 12px;font-weight:800;transition:transform .24s,box-shadow .24s,border-color .24s}.admin-row button:hover{box-shadow:var(--box-shadow);border-color:#6366f16b;transform:translateY(-2px)scale(1.03)}@media (width<=960px){.admin-grid,.admin-row{grid-template-columns:1fr}.admin-form{position:static}}.auth-page{background:linear-gradient(135deg,#38bdf82e,#c084fc33),#f8fbff;grid-template-columns:minmax(0,1fr) 460px;min-height:100vh;display:grid}.compact-auth{grid-template-columns:1fr}.auth-visual{color:#fff;background:linear-gradient(135deg,#38bdf838,#4f46e5c2),url(/assets/hero-CLDdwZDr.png) 50%/cover;align-items:flex-end;min-height:100vh;padding:56px;display:flex}.auth-visual h1{letter-spacing:0;max-width:760px;margin:10px 0 16px;font-size:clamp(42px,6vw,76px);line-height:.96}.auth-visual p{color:#dbeafe;max-width:620px;font-size:18px}.auth-kicker{color:#38bdf8;letter-spacing:.12em;text-transform:uppercase;font-size:12px;font-weight:900}.auth-panel{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffc2;place-items:center;padding:32px;display:grid}.auth-form{border-radius:var(--border-radius-lg);width:min(100%,380px);box-shadow:var(--box-shadow);background:#ffffffd1;border:1px solid #ffffffbd;gap:18px;padding:26px;animation:.38s both fadeSlideIn;display:grid}.auth-form h2{margin-top:6px;font-size:34px;line-height:1}.auth-form label,.movie-form label,.search-box{color:var(--text-muted);gap:8px;font-size:13px;font-weight:800;display:grid}.auth-form input,.movie-form input,.movie-form textarea,.search-box input{border:1px solid var(--border-color);border-radius:var(--border-radius);width:100%;color:var(--text-color);background:#ffffffe6;outline:none;padding:12px 14px}.auth-form input:focus,.movie-form input:focus,.movie-form textarea:focus,.search-box input:focus{border-color:var(--primary-color);box-shadow:var(--focus-ring);transform:translateY(-1px)}.auth-error{border-radius:var(--border-radius);color:var(--danger-color);background:#fef2f2eb;padding:12px 14px;font-size:14px;font-weight:700;animation:.32s both fadeSlideIn;box-shadow:0 12px 28px #ef44441f}.auth-link{color:var(--text-muted);text-align:center}.auth-link a{color:var(--primary-color);font-weight:800}@media (width<=900px){.auth-page{grid-template-columns:1fr}.auth-visual{min-height:42vh;padding:32px}}.booking-page{max-width:1280px;margin:0 auto}.booking-event-meta{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.booking-event-meta span{border:1px solid var(--border-color);color:var(--text-muted);background:#ffffffc7;border-radius:999px;padding:7px 10px;font-size:13px;font-weight:800}.booking-showtimes{margin-bottom:24px}.booking-showtime-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;display:grid}.booking-showtime-card{border:1px solid var(--border-color);border-radius:var(--border-radius);min-height:150px;color:var(--text-color);text-align:left;box-shadow:var(--box-shadow);background:#ffffffe0;gap:8px;padding:16px;transition:border-color .25s,box-shadow .25s,transform .25s,background .25s;display:grid}.booking-showtime-card:hover,.booking-showtime-card.active{border-color:var(--primary-color);box-shadow:var(--box-shadow-hover);transform:translateY(-4px)scale(1.02)}.booking-showtime-card.active{background:linear-gradient(135deg,#eff6fff5,#f5f3fff5)}.booking-showtime-card strong{font-size:18px;line-height:1.2}.booking-showtime-card span{color:var(--primary-color);font-weight:900}.booking-showtime-card small{color:var(--text-muted);font-weight:800}.booking-placeholder,.booking-selected-header{border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--box-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe0}.booking-placeholder{color:var(--text-muted);text-align:center;gap:8px;margin-top:18px;padding:26px;display:grid}.booking-placeholder strong{color:var(--text-color);font-size:20px}.booking-selected-header{justify-content:space-between;align-items:flex-end;gap:18px;margin:24px 0;padding:22px;display:flex}.booking-selected-header h2{margin-top:6px;font-size:clamp(24px,3vw,34px)}.booking-selected-header p{color:var(--text-muted);margin-top:8px}.booking-workspace{grid-template-columns:minmax(0,1fr) 340px;align-items:start;gap:24px;display:grid}.seat-map-panel,.booking-summary{border:1px solid var(--border-color);border-radius:var(--border-radius-lg);background:var(--surface-color);box-shadow:var(--box-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.seat-map-panel{padding:28px;overflow-x:auto}.booking-page-screen{color:#334155;text-align:center;letter-spacing:.16em;background:linear-gradient(#cbd5e1,#f8fafc);border-radius:0 0 50% 50%;width:min(680px,100%);margin:0 auto 36px;padding:14px;font-size:12px;font-weight:900}.booking-page-grid{grid-template-columns:repeat(10,44px);justify-content:center;gap:12px;min-width:548px;margin-bottom:28px;display:grid}.booking-page-seat{border:0;border-radius:10px 10px 15px 15px;place-items:center;width:44px;height:40px;font-size:12px;font-weight:900;transition:transform .2s,box-shadow .2s,filter .2s;display:grid}.booking-page-seat:hover:not(:disabled){transform:translateY(-3px)scale(1.06);box-shadow:0 10px 22px #4f46e52e}.seat-available{background:var(--seat-available);color:var(--seat-available-text)}.seat-selected{background:var(--seat-selected);color:#fff}.seat-held{background:var(--seat-held);color:#fff}.seat-sold{background:var(--seat-sold);color:#fff}.seat-legend{color:var(--text-muted);flex-wrap:wrap;justify-content:center;gap:14px;font-size:13px;font-weight:700;display:flex}.seat-legend span{align-items:center;gap:8px;display:inline-flex}.seat-legend i{border-radius:4px;width:14px;height:14px}.legend-available{background:var(--seat-available)}.legend-selected{background:var(--seat-selected)}.legend-held{background:var(--seat-held)}.legend-sold{background:var(--seat-sold)}.booking-summary{padding:24px;position:sticky;top:24px}.booking-summary h2{margin:8px 0 20px;font-size:24px}.booking-summary dl{gap:16px;margin:0 0 24px;display:grid}.booking-summary dl div{border-bottom:1px solid var(--border-color);gap:6px;padding-bottom:14px;display:grid}.booking-summary dt{color:var(--text-muted);font-size:13px;font-weight:800}.booking-summary dd{margin:0;font-size:18px;font-weight:900}.booking-summary .primary-button{width:100%}@media (width<=1020px){.booking-workspace{grid-template-columns:1fr}.booking-summary{position:static}.booking-selected-header{flex-direction:column;align-items:stretch}}.home-page,.movie-detail-page{z-index:1;max-width:1240px;margin:0 auto;padding:32px 28px 56px;position:relative}.home-hero{border-radius:var(--border-radius-lg);color:#fff;cursor:grab;-webkit-user-select:none;user-select:none;will-change:background-image;background-color:#0000;background-image:linear-gradient(90deg,#0f172a9e 0%,#4f46e56b 48%,#0ea5e92e 100%),linear-gradient(#ffffff0f,#0f172a3d),url(/assets/hero-CLDdwZDr.png);background-position:50%;background-repeat:repeat,repeat,repeat;background-size:cover;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;align-items:flex-end;min-height:460px;padding:44px;transition:box-shadow .25s;display:flex;position:relative;overflow:hidden;box-shadow:0 24px 58px #4f46e529,0 12px 26px #0f172a14}.home-hero:active{cursor:grabbing}.home-hero:hover{box-shadow:0 28px 64px #4f46e52e,0 14px 30px #0f172a1a}.home-hero:before{pointer-events:none;content:"";background-color:#0000;background-image:linear-gradient(90deg,#ffffff2e 1px,#0000 1px),linear-gradient(#ffffff1f 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:72px 72px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:absolute;inset:0;-webkit-mask-image:linear-gradient(90deg,#00000052,#0000 68%);mask-image:linear-gradient(90deg,#00000052,#0000 68%)}.home-hero-content{z-index:1;max-width:760px;animation:.26s both heroContentIn;position:relative}.hero-arrow{z-index:2;color:#fff;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff2e;border:1px solid #ffffff47;border-radius:50%;place-items:center;width:42px;height:42px;font-size:30px;line-height:1;transition:transform .18s,background .18s;display:grid;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 10px 22px #0f172a1f}.hero-arrow:hover{background:#ffffff47;transform:translateY(-50%)scale(1.04)}.hero-arrow-left{left:18px}.hero-arrow-right{right:18px}.hero-dots{z-index:2;gap:8px;display:flex;position:absolute;bottom:24px;right:28px}.hero-dots button{background:#ffffff80;border:0;border-radius:999px;width:9px;height:9px;padding:0;transition:width .24s,background .24s}.hero-dots button.active{background:#fff;width:28px}.home-hero h1{max-width:760px;margin:8px 0 12px;font-size:clamp(44px,7vw,82px);line-height:.95}.home-hero p{color:#e2e8f0;max-width:640px;margin-bottom:22px;font-size:18px}.movie-section,.showtime-section{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff7a;border:1px solid #94a3b824;border-radius:22px;margin-top:34px;padding:28px;box-shadow:0 24px 70px #4f46e514}.public-movie-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:18px;display:grid}.public-movie-card{border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--box-shadow);background:#ffffffe0;gap:10px;padding:12px;transition:transform .25s,box-shadow .25s,border-color .25s;animation:.45s both cardFloatIn;display:grid;overflow:hidden}.public-movie-card:hover,.public-movie-card.active{box-shadow:var(--box-shadow-hover);border-color:#6366f161;transform:translateY(-4px)scale(1.02)}.public-movie-card.active{background:linear-gradient(135deg,#fffffff0,#f5f3fff0)}.movie-card-button{color:inherit;text-align:left;background:0 0;border:0;gap:10px;padding:0;display:grid}.public-poster,.detail-poster{border-radius:var(--border-radius);color:#075985;background:#e0f2fe;place-items:center;font-weight:900;display:grid;overflow:hidden}.public-poster{height:280px;font-size:34px}.public-poster img,.detail-poster img{object-fit:cover;width:100%;height:100%}.public-movie-card h3{font-size:18px}.public-movie-card p{color:var(--text-muted)}.movie-card-cta{border-radius:var(--border-radius);background:var(--primary-soft);width:fit-content;color:var(--primary-color);padding:8px 10px;font-size:13px;font-weight:900;display:inline-flex}.movie-showtime-panel{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff8f;border:1px solid #94a3b824;border-radius:22px;margin-top:18px;padding:22px;animation:.28s both showtimeDrop;box-shadow:0 18px 48px #4f46e514}.selected-showtime-header{justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:16px;display:flex}.selected-showtime-header h2{margin-top:6px;font-size:clamp(24px,3vw,34px)}.selected-showtime-header p{max-width:760px;color:var(--text-muted);margin-top:8px}.movie-showtime-list{gap:10px;display:grid}.movie-showtime-option{border:1px solid var(--border-color);border-radius:var(--border-radius);width:100%;color:var(--text-color);text-align:left;background:#ffffffdb;gap:4px;padding:12px;transition:transform .24s,box-shadow .24s,border-color .24s;animation:.24s both fadeSlideIn;display:grid}.movie-showtime-option:hover{border-color:#6366f161;transform:translateY(-2px)scale(1.01);box-shadow:0 12px 24px #4f46e524}.movie-showtime-option strong{color:var(--primary-color)}.movie-showtime-option span,.movie-showtime-option small{color:var(--text-muted);font-weight:800}.inline-error{border-radius:var(--border-radius);color:var(--danger-color);background:#fef2f2eb;padding:10px 12px;font-size:13px;font-weight:800;animation:.24s both fadeSlideIn}.empty-state.compact{padding:14px;font-size:13px}.movie-detail-hero{border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--box-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe6;grid-template-columns:320px minmax(0,1fr);align-items:stretch;gap:32px;padding:24px;display:grid}.detail-poster{min-height:420px}.movie-detail-hero h1{margin:8px 0 14px;font-size:clamp(38px,5vw,64px);line-height:1}.movie-detail-hero p{color:var(--text-muted);line-height:1.7}.detail-meta{grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px;display:grid}.detail-meta div{border:1px solid var(--border-color);border-radius:var(--border-radius);background:#ffffffbd;padding:14px}.detail-meta dt{color:var(--text-muted);text-transform:uppercase;font-size:12px;font-weight:900}.detail-meta dd{margin:6px 0 0;font-weight:900}.showtime-list{gap:12px;display:grid}.show-all-button{margin:-12px 0 18px}.showtime-item{border:1px solid var(--border-color);border-radius:var(--border-radius-lg);background:#ffffffe6;grid-template-columns:180px minmax(0,1fr) 180px;align-items:center;gap:12px;padding:16px;transition:transform .25s,box-shadow .25s,border-color .25s;display:grid;box-shadow:0 10px 28px #4f46e514}.showtime-item:hover{box-shadow:var(--box-shadow-hover);border-color:#6366f161;transform:translateY(-3px)scale(1.01)}.showtime-item strong{font-size:16px}.showtime-item span{gap:4px;display:grid}.showtime-item small{color:var(--text-muted)}.showtime-meta{justify-items:end}.showtime-meta b{color:var(--primary-color)}@media (width<=840px){.movie-detail-hero,.detail-meta,.showtime-item{grid-template-columns:1fr}}@keyframes heroContentIn{0%{opacity:.72;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes cardFloatIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes showtimeDrop{0%{opacity:0;transform:translateY(-8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.movie-admin-page{max-width:1360px;margin:0 auto}.search-box{width:min(100%,320px)}.movie-admin-layout{grid-template-columns:360px minmax(0,1fr);align-items:start;gap:24px;display:grid}.movie-form,.movie-list-panel{border:1px solid var(--border-color);border-radius:var(--border-radius-lg);background:var(--surface-color);box-shadow:var(--box-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:.35s both fadeSlideIn}.movie-form{gap:14px;padding:22px;display:grid;position:sticky;top:24px}.movie-form h2{font-size:22px}.movie-form textarea{resize:vertical}.form-actions{gap:10px;display:flex}.movie-list-panel{padding:18px}.movie-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.movie-card{border:1px solid var(--border-color);border-radius:var(--border-radius-lg);background:#ffffffe6;grid-template-rows:220px 1fr auto;transition:transform .25s,box-shadow .25s,border-color .25s;display:grid;overflow:hidden;box-shadow:0 10px 28px #4f46e514}.movie-card:hover{box-shadow:var(--box-shadow-hover);border-color:#6366f161;transform:translateY(-4px)scale(1.02)}.movie-poster{color:#075985;background:linear-gradient(135deg,#e0f2fe,#f5f3ff);place-items:center;font-size:38px;font-weight:900;display:grid;overflow:hidden}.movie-poster img{object-fit:cover;width:100%;height:100%}.movie-card-body{gap:6px;padding:14px;display:grid}.movie-card-body h3{font-size:18px;line-height:1.2}.movie-card-body p,.movie-card-body small{color:var(--text-muted)}.movie-card-actions{border-top:1px solid var(--border-color);grid-template-columns:1fr 1fr;display:grid}.movie-card-actions button{border:0;border-right:1px solid var(--border-color);color:var(--text-color);background:#ffffffdb;padding:12px;font-weight:800;transition:background .24s,transform .24s}.movie-card-actions button:hover{background:#eef2ffcc;transform:translateY(-1px)}.movie-card-actions button:last-child{color:var(--danger-color);border-right:0}.empty-state{border:1px dashed var(--border-color);border-radius:var(--border-radius);color:var(--text-muted);text-align:center;background:#ffffffb3;grid-column:1/-1;padding:28px;font-weight:700}@media (width<=1060px){.movie-admin-layout{grid-template-columns:1fr}.movie-form{position:static}}.user-page{max-width:960px;margin:0 auto}.payment-card,.profile-form,.ticket-detail,.ticket-list{border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--box-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe0;animation:.35s both fadeSlideIn}.payment-card,.profile-form,.ticket-detail{gap:20px;padding:24px;display:grid}.payment-card dl,.ticket-detail dl{gap:12px;margin:0;display:grid}.payment-card dl div,.ticket-detail dl div{border-bottom:1px solid var(--border-color);justify-content:space-between;gap:14px;padding-bottom:12px;display:flex}.payment-card dt,.ticket-detail dt{color:var(--text-muted);font-weight:800}.payment-card dd,.ticket-detail dd{margin:0;font-weight:900}.countdown{border-radius:var(--border-radius);color:var(--primary-color);background:linear-gradient(135deg,#eff6fff2,#f5f3fff2);place-items:center;padding:24px;display:grid;box-shadow:inset 0 0 0 1px #6366f11f}.countdown strong{font-size:56px;line-height:1}.countdown.urgent{color:var(--danger-color);background:#fef2f2f0;animation:1s ease-in-out infinite buttonPulse}.ticket-list{overflow:hidden}.ticket-row{border-bottom:1px solid var(--border-color);grid-template-columns:120px 1fr 120px;align-items:center;gap:14px;padding:16px;transition:transform .24s,background .24s;display:grid}.ticket-row:hover{background:#eef2ffb8;transform:translate(4px)}.ticket-row:last-child{border-bottom:0}.status-pill{color:var(--text-muted);background:#f1f5f9;border-radius:999px;justify-content:center;padding:6px 10px;font-size:12px;font-weight:900;display:inline-flex}.status-pill.completed,.status-pill.paid{color:var(--success-color);background:#ecfdf5}.status-pill.cancelled,.status-pill.expired{color:var(--danger-color);background:#fef2f2}.ticket-detail{grid-template-columns:max-content minmax(0,1fr);align-items:center}.profile-form label,.admin-form label{color:var(--text-muted);gap:8px;font-size:13px;font-weight:800;display:grid}.profile-form input,.admin-form input,.admin-form select{border:1px solid var(--border-color);border-radius:var(--border-radius);background:#ffffffeb;padding:12px 14px}@media (width<=720px){.ticket-row,.ticket-detail{grid-template-columns:1fr}}.register-page-wrapper{background:linear-gradient(135deg, #38bdf82e, #c084fc33), var(--bg-color);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.register-page-box{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:var(--border-radius-lg);box-shadow:var(--box-shadow);text-align:center;background:#ffffffd6;border:1px solid #ffffffbd;width:100%;max-width:450px;padding:40px;animation:.36s both fadeSlideIn}.register-page-title{margin-bottom:24px;font-size:24px}.register-page-input{border:1px solid var(--border-color);border-radius:var(--border-radius);background:#ffffffeb;width:100%;margin-bottom:16px;padding:12px 16px;font-size:16px;transition:border-color .3s,box-shadow .3s,transform .25s}.register-page-input:focus{border-color:var(--primary-color);box-shadow:var(--focus-ring);outline:none;transform:translateY(-1px)}.register-page-btn{background:var(--brand-gradient);color:#fff;border-radius:var(--border-radius);cursor:pointer;background-size:180% 180%;border:none;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:10px;padding:12px;font-size:16px;font-weight:700;transition:transform .25s,box-shadow .25s,filter .25s;display:inline-flex;position:relative;box-shadow:0 12px 26px #4f46e533}.register-page-btn:hover:not(:disabled){box-shadow:var(--box-shadow-hover);animation:2.2s infinite gradientShift;transform:translateY(-2px)scale(1.03)}.register-page-btn:disabled{cursor:not-allowed;opacity:.68;animation:1.2s ease-in-out infinite buttonPulse}.register-page-btn:disabled:after{content:"";border:2px solid;border-right-color:#0000;border-radius:50%;width:14px;height:14px;animation:.75s linear infinite spin}.register-page-error{border-radius:var(--border-radius);color:var(--danger-color);text-align:left;background:#fef2f2eb;margin-bottom:16px;padding:12px 14px;font-size:14px;animation:.32s both fadeSlideIn}.register-page-success{border-radius:var(--border-radius);color:var(--success-color);background:#ecfdf5eb;margin-bottom:16px;padding:12px 14px;font-size:14px;font-weight:700;animation:.32s both fadeSlideIn}.register-page-link{color:var(--text-color);margin-top:20px;font-size:14px;display:block}.register-page-link a{color:var(--primary-color);font-weight:700;text-decoration:none}.register-page-link a:hover{text-decoration:underline}:root{--primary-color:#4f46e5;--primary-hover:#7c3aed;--primary-soft:#eef2ff;--accent-color:#f59e0b;--accent-soft:#fff7ed;--brand-gradient:linear-gradient(135deg, #38bdf8 0%, #6366f1 50%, #c084fc 100%);--warm-gradient:linear-gradient(135deg, #fb923c 0%, #facc15 100%);--bg-color:#f8fbff;--surface-color:#ffffffdb;--surface-muted:#f4f7ff;--text-color:#172033;--text-muted:#64748b;--border-color:#94a3b83d;--danger-color:#ef4444;--success-color:#10b981;--warning-color:#f59e0b;--seat-available:#e9eefb;--seat-available-text:#334155;--seat-selected:#6366f1;--seat-held:#f59e0b;--seat-sold:#ef4444;--border-radius:14px;--border-radius-lg:16px;--box-shadow:0 18px 45px #4f46e51f, 0 8px 18px #0f172a14;--box-shadow-hover:0 24px 60px #4f46e52e, 0 12px 28px #0f172a1a;--focus-ring:0 0 0 4px #6366f129}*{box-sizing:border-box}html{background:linear-gradient(145deg, #eaf8fff5 0%, #f8fbfffa 38%, #f6f4fff2 100%), linear-gradient(90deg, #6366f10e 1px, transparent 1px), linear-gradient(180deg, #0ea5e90b 1px, transparent 1px), var(--bg-color);background-size:auto,44px 44px,44px 44px,auto}body{color:var(--text-color);background:linear-gradient(#ffffff61,#f8fbffeb),0 0}h1,h2,h3,p{margin:0}.page-header{justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:24px;display:flex}.page-header h1{letter-spacing:0;margin-top:6px;font-size:clamp(30px,4vw,48px);line-height:1}.page-header p{max-width:680px;color:var(--text-muted);margin-top:12px}.page-kicker{color:var(--primary-color);letter-spacing:.12em;text-transform:uppercase;font-size:12px;font-weight:800}.primary-button,.ghost-button{border-radius:var(--border-radius);border:1px solid #0000;justify-content:center;align-items:center;gap:10px;min-height:44px;padding:0 18px;font-weight:800;transition:transform .25s,box-shadow .25s,filter .25s,border-color .25s;display:inline-flex;position:relative;box-shadow:0 10px 22px #4f46e524}.primary-button{background:var(--brand-gradient);color:#fff;background-size:180% 180%}.primary-button:hover:not(:disabled){box-shadow:var(--box-shadow-hover);filter:saturate(1.08);animation:2.2s infinite gradientShift;transform:translateY(-2px)scale(1.03)}.ghost-button{color:var(--text-color);border-color:var(--border-color);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffc7}.ghost-button:hover:not(:disabled){box-shadow:var(--box-shadow);border-color:#6366f16b;transform:translateY(-2px)scale(1.02)}.primary-button:disabled,.ghost-button:disabled{opacity:.68;animation:1.2s ease-in-out infinite buttonPulse}.primary-button:disabled:after,.ghost-button:disabled:after{content:"";border:2px solid;border-right-color:#0000;border-radius:50%;width:14px;height:14px;animation:.75s linear infinite spin}.success-banner{border-radius:var(--border-radius);color:var(--success-color);background:#ecfdf5e6;border:1px solid #0596694d;margin-bottom:18px;padding:14px 16px;font-weight:700;animation:.35s both fadeSlideIn;box-shadow:0 12px 28px #10b9811f}input,textarea,select{transition:border-color .3s,box-shadow .3s,transform .25s,background .3s}input:focus,textarea:focus,select:focus{border-color:var(--primary-color);box-shadow:var(--focus-ring)}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes buttonPulse{0%,to{filter:brightness()}50%{filter:brightness(1.08)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@media (width<=820px){.page-header{flex-direction:column;align-items:stretch}}
