@import"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@400;600&family=Space+Grotesk:wght@500;700&display=swap";:root{--header-height: 64px;--bg-primary: #ffffff;--bg-secondary: #ffffff;--text-primary: #363636;--text-secondary: #757575;--border-color: #e5e5e5;--accent-color: #2196f3;--accent-hover: #1976d2;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 16px rgba(0, 0, 0, .12)}html.dark-mode{--bg-primary: #2d2d2d;--bg-secondary: #2d2d2d;--text-primary: #ffffff;--text-secondary: #adb5bd;--border-color: #404040;--accent-color: #42a5f5;--accent-hover: #2196f3;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);min-height:100vh;transition:background-color .2s ease;color:var(--text-primary)}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-container{display:flex;flex:1;overflow:hidden}.app-container-immersive{overflow:auto}.main-content{flex:1;overflow-y:auto;background:var(--bg-primary);position:relative;transition:background .3s ease;width:100%;padding-top:var(--header-height)}.main-content-immersive{padding-top:0}.message{position:fixed;top:90px;right:20px;padding:15px 20px;border-radius:10px;display:flex;align-items:center;justify-content:space-between;gap:15px;max-width:400px;animation:slideIn .3s ease-out;box-shadow:0 5px 20px #0003;z-index:1001;font-weight:600}@keyframes slideIn{0%{transform:translate(420px);opacity:0}to{transform:translate(0);opacity:1}}.message-success{background-color:#4caf50;color:#fff}.message-error{background-color:#f44336;color:#fff}.message-warning{background-color:#ff9800;color:#fff}.message-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1.2em;padding:0;opacity:.8;transition:opacity .2s}.message-close:hover{opacity:1}.error-log-panel{position:fixed;bottom:20px;right:20px;background-color:#fff;border:2px solid #ff9800;border-radius:10px;box-shadow:0 10px 30px #0000004d;max-width:500px;max-height:600px;display:flex;flex-direction:column;z-index:999;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(650px);opacity:0}to{transform:translateY(0);opacity:1}}.error-log-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:2px solid #ff9800;background-color:#fff8f0}.error-log-header h3{margin:0;color:#d32f2f;font-size:1.1em}.error-log-close{background:none;border:none;font-size:1.5em;color:#d32f2f;cursor:pointer;transition:transform .2s}.error-log-close:hover{transform:scale(1.2)}.error-log-content{overflow-y:auto;flex:1;padding:15px}.error-log-item{margin-bottom:15px;padding:12px;background-color:#f5f5f5;border-left:4px solid #d32f2f;border-radius:4px;font-family:Courier New,monospace;font-size:.85em}.error-log-time{color:#666;font-size:.8em;margin-bottom:8px}.error-log-message{color:#d32f2f;margin-bottom:8px;word-break:break-word}.error-log-context{color:#666;font-size:.8em;margin-bottom:8px}.error-log-stack{margin-top:8px;cursor:pointer}.error-log-stack summary{color:#06c;text-decoration:underline;padding:5px;border-radius:3px;transition:background-color .2s}.error-log-stack summary:hover{background-color:#e3f2fd}.error-log-stack pre{background-color:#fff;border:1px solid #ddd;padding:10px;border-radius:4px;overflow-x:auto;max-height:200px;overflow-y:auto;margin:10px 0 0;color:#333}.tool-content{width:100%;max-width:100%}@media (min-width: 769px){.sidemenu{transform:translate(0)!important}}@media (max-width: 768px){.message{top:80px;right:10px;left:10px;max-width:unset}.error-log-panel{right:10px;left:10px;max-width:unset;bottom:60px}}@media (max-width: 480px){.message{top:75px;right:5px;left:5px;padding:12px 15px;font-size:.9em}.error-log-panel{right:5px;left:5px;max-height:50vh;bottom:50px}.error-log-content{padding:10px}.error-log-item{padding:10px;font-size:.8em;margin-bottom:10px}}.main-content::-webkit-scrollbar,.sidemenu-nav::-webkit-scrollbar,.error-log-content::-webkit-scrollbar{width:8px}.main-content::-webkit-scrollbar-track,.sidemenu-nav::-webkit-scrollbar-track,.error-log-content::-webkit-scrollbar-track{background:#0000001a}.main-content::-webkit-scrollbar-thumb,.sidemenu-nav::-webkit-scrollbar-thumb,.error-log-content::-webkit-scrollbar-thumb{background:#667eea80;border-radius:4px}.main-content::-webkit-scrollbar-thumb:hover,.sidemenu-nav::-webkit-scrollbar-thumb:hover,.error-log-content::-webkit-scrollbar-thumb:hover{background:#667eeab3}.header{height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:fixed;top:0;left:0;right:0;z-index:100;box-shadow:var(--shadow-sm)}.header-container{max-width:1400px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 24px;gap:24px}.header-logo{cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:8px;text-decoration:none}.header-logo h1{font-size:22px;font-weight:700;margin:0;color:var(--accent-color);letter-spacing:-.5px}.header-nav{display:flex;gap:4px;flex:1;max-width:none;min-width:0;justify-content:center}.nav-link{background:none;border:none;color:var(--text-primary);font-size:15px;font-weight:500;padding:8px 16px;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:flex;align-items:center;gap:6px;text-decoration:none}.nav-link:hover{background:var(--bg-primary);color:var(--accent-color)}.nav-dropdown{position:relative}.dropdown-arrow{font-size:10px;transition:transform .2s ease}.nav-dropdown:hover .dropdown-arrow{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:50%;min-width:280px;max-height:70vh;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #0000001f;padding:16px 12px 12px;margin-top:0;z-index:1000;opacity:0;visibility:hidden;pointer-events:none;transform:translate(-50%,-8px);transition:opacity .18s ease,transform .18s ease,visibility .18s ease}.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%)}.dropdown-menu.large{min-width:360px;max-width:980px;overflow-x:auto}.dropdown-menu.mega{min-width:720px;max-width:980px;padding:16px;overflow-x:auto}.dropdown-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.dropdown-section.span-all{grid-column:1 / -1}.image-columns{display:grid;gap:12px;grid-auto-flow:column;grid-auto-columns:minmax(140px,1fr);align-items:start;padding-bottom:4px;overflow-x:auto}.image-column{display:grid;gap:6px;min-width:140px}.image-column-title{font-size:13px;font-weight:600;color:var(--text-secondary);padding:0 8px}.image-list{display:flex;flex-direction:column;gap:6px;padding:4px 0}.image-list-divider{height:1px;background:var(--border-color);margin:6px 8px;opacity:.6}.dropdown-items{display:grid;gap:6px}.dropdown-items.columns-2{grid-template-columns:repeat(2,minmax(0,1fr))}.dropdown-items.columns-3{grid-template-columns:repeat(3,minmax(0,1fr))}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-section{padding:8px 0}.dropdown-title{font-size:13px;font-weight:600;color:var(--text-secondary);margin:0 0 8px 12px;text-transform:uppercase;letter-spacing:.5px}.dropdown-item{width:100%;background:none;border:none;color:var(--text-primary);font-size:14px;font-weight:500;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;display:flex;align-items:center;gap:10px;position:relative;text-decoration:none}.dropdown-item.compact{padding:8px 10px;font-size:13px}.dropdown-item:hover:not(.disabled){background:var(--bg-primary);color:var(--accent-color)}.dropdown-item.disabled{opacity:.5;cursor:not-allowed}.tool-icon{font-size:14px;flex-shrink:0}.coming-soon{margin-left:auto;font-size:11px;color:var(--text-secondary);background:var(--border-color);padding:2px 8px;border-radius:4px;font-weight:600}.dropdown-divider{height:1px;background:var(--border-color);margin:8px 0}.header-actions{display:flex;align-items:center;gap:12px}.header-sponsor{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;background:var(--accent-color);color:#fff;font-size:13px;font-weight:600;text-decoration:none;white-space:nowrap;transition:transform .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-sm)}.header-sponsor:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.language-switcher{display:flex;align-items:center;gap:4px;background:var(--bg-primary);border-radius:6px;padding:4px}.lang-btn{background:none;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;padding:6px 12px;border-radius:4px;cursor:pointer;transition:all .2s ease}.lang-btn:hover{color:var(--text-primary)}.lang-btn.active{background:var(--bg-secondary);color:var(--accent-color);font-weight:600;box-shadow:var(--shadow-sm)}.lang-divider{display:none}.theme-toggle{background:var(--bg-primary);border:none;color:var(--text-primary);width:36px;height:36px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s ease}.theme-toggle:hover{background:var(--border-color)}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:4px;z-index:1001}.menu-toggle span{width:24px;height:2px;background:var(--text-primary);border-radius:2px;transition:all .3s ease}.mobile-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:998}.mobile-menu{display:none;position:fixed;top:var(--header-height);right:0;width:280px;max-width:80vw;height:calc(100vh - var(--header-height));background:var(--bg-secondary);border-left:1px solid var(--border-color);box-shadow:-4px 0 12px #0000001a;overflow-y:auto;z-index:999;padding:16px;animation:slideInRight .3s ease}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-nav-link{width:100%;background:none;border:none;color:var(--text-primary);font-size:15px;font-weight:500;padding:12px 16px;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;display:block;margin-bottom:4px;text-decoration:none}.mobile-nav-link:hover:not(.disabled){background:var(--bg-primary);color:var(--accent-color)}.mobile-nav-link.disabled{opacity:.5;cursor:not-allowed}.mobile-section{margin:16px 0;padding:12px 0;border-top:1px solid var(--border-color)}.mobile-section:first-child{border-top:none;margin-top:0}.mobile-section-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 16px}.mobile-tool{display:flex;align-items:center;gap:12px;position:relative}.mobile-tool .tool-icon{font-size:14px}.mobile-tool .coming-soon{margin-left:auto;font-size:10px;color:var(--text-secondary);background:var(--border-color);padding:2px 6px;border-radius:4px;font-weight:600}@media (max-width: 768px){.header-container{padding:0 16px}.header-logo h1{font-size:18px}.header-nav{display:none}.menu-toggle{display:flex}.mobile-overlay,.mobile-menu{display:block}.language-switcher{padding:2px}.lang-btn{padding:4px 8px;font-size:12px}.theme-toggle{width:32px;height:32px;font-size:14px}}@media (min-width: 1200px){.dropdown-menu.large,.dropdown-menu.mega{width:min(1200px,calc(100vw - 80px));max-width:min(1200px,calc(100vw - 80px));overflow-x:visible}.nav-dropdown:hover .dropdown-menu.large,.nav-dropdown:hover .dropdown-menu.mega{transform:translate(-50%)}.image-columns{overflow-x:visible}}.logo-highlight{color:var(--accent-color);font-weight:800}.site-footer{border-top:1px solid var(--border-color);background:var(--bg-secondary);padding:14px 24px}.site-footer-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:12px;color:var(--text-secondary);font-size:13px}.footer-sponsor{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;border:1px solid var(--accent-color);color:var(--accent-color);text-decoration:none;font-weight:600}.footer-sponsor:hover{background:var(--accent-color);color:#fff}@media (max-width: 720px){.site-footer-inner{flex-direction:column;text-align:center}}.home{padding-top:0;min-height:100vh;background:var(--bg-primary);position:relative;overflow:hidden}.home-decor{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.home-orb{position:absolute;border-radius:50%;filter:blur(0)}.home-orb-1{width:420px;height:420px;top:-140px;right:-160px;background:radial-gradient(circle at 30% 30%,rgba(33,150,243,.25),transparent 70%)}.home-orb-2{width:320px;height:320px;top:240px;left:-140px;background:radial-gradient(circle at 40% 40%,rgba(33,150,243,.18),transparent 70%)}.home-orb-3{width:260px;height:260px;bottom:280px;right:6%;background:radial-gradient(circle at 45% 45%,rgba(33,150,243,.2),transparent 72%)}.home-orb-4{width:380px;height:380px;bottom:-200px;left:18%;background:radial-gradient(circle at 35% 35%,rgba(33,150,243,.16),transparent 72%)}html.dark-mode .home-orb-1{background:radial-gradient(circle at 30% 30%,rgba(66,165,245,.3),transparent 70%)}html.dark-mode .home-orb-2{background:radial-gradient(circle at 40% 40%,rgba(66,165,245,.22),transparent 70%)}html.dark-mode .home-orb-3{background:radial-gradient(circle at 45% 45%,rgba(66,165,245,.2),transparent 70%)}html.dark-mode .home-orb-4{background:radial-gradient(circle at 35% 35%,rgba(66,165,245,.18),transparent 72%)}.home>section,.home>.wishpool-section{position:relative;z-index:1}.hero{padding:60px 24px 40px;text-align:center;position:relative}.hero-content{max-width:900px;margin:0 auto;background:linear-gradient(140deg,#2196f31f,#2196f305);border:1px solid rgba(33,150,243,.16);border-radius:22px;padding:38px 32px;box-shadow:var(--shadow-sm)}.hero h1{font-size:42px;font-weight:700;margin:0 0 16px;color:var(--text-primary);line-height:1.2}.progress-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:linear-gradient(90deg,#2196f32e,#2196f30a);border:1px solid rgba(33,150,243,.25);color:var(--text-secondary);font-size:13px;font-weight:600;margin:0 auto 16px}.progress-count{color:var(--text-primary)}.progress-input{width:52px;text-align:center;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#00000059;color:var(--text-primary);padding:2px 6px;font-size:13px;font-weight:600}.progress-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #d5443e33}.hero p{font-size:18px;color:var(--text-secondary);margin:0 0 40px;line-height:1.6}.hero-link{color:var(--accent-color);font-weight:700;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;margin:0 4px}.hero-link:hover{color:var(--accent-color)}.hero-button{background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));color:#fff;border:none;padding:16px 48px;font-size:17px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-md);display:inline-flex;align-items:center;gap:8px}.hero-button:hover{background:linear-gradient(135deg,var(--accent-hover),var(--accent-color));transform:translateY(-2px);box-shadow:0 6px 20px #d5443e4d}.home-avatar{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:10px 24px 30px;gap:10px;position:relative}.avatar-toggle{border:none;background:transparent;padding:0;cursor:pointer;position:relative;width:clamp(140px,22vw,220px);aspect-ratio:1 / 1;-webkit-tap-highlight-color:transparent}.avatar-toggle img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;border-radius:0;box-shadow:none;transition:transform .2s ease;object-fit:contain}.avatar-bubble{position:absolute;bottom:12%;opacity:0;animation-name:bubble-float;animation-timing-function:ease-out;animation-fill-mode:forwards;pointer-events:none;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.avatar-counter{font-size:.95rem;color:var(--text-secondary)}.avatar-counter-sub{font-size:.85rem;opacity:.8}.avatar-reset{border:1px solid rgba(239,68,68,.4);background:#ef444414;color:#b91c1c;border-radius:999px;padding:6px 12px;font-size:.8rem;cursor:pointer}.avatar-admin-controls{display:grid;gap:8px;align-items:center;justify-items:center}.avatar-edit-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center}.avatar-edit-input{width:120px;border:1px solid rgba(148,163,184,.6);border-radius:999px;padding:6px 10px;font-size:.85rem;background:#ffffffe6;color:var(--text-primary);text-align:center}.avatar-edit-save{border:1px solid rgba(59,130,246,.35);background:#3b82f61f;color:#1d4ed8;border-radius:999px;padding:6px 12px;font-size:.8rem;cursor:pointer}.avatar-edit-save:disabled{opacity:.6;cursor:not-allowed}html.dark-mode .avatar-reset{border:1px solid rgba(248,113,113,.4);background:#f871711f;color:#fecaca}html.dark-mode .avatar-edit-input{border:1px solid rgba(148,163,184,.35);background:#0f172a99;color:#f8fafc}html.dark-mode .avatar-edit-save{border:1px solid rgba(59,130,246,.5);background:#3b82f633;color:#bfdbfe}@keyframes bubble-float{0%{transform:translate(-50%,10px);opacity:0}20%{opacity:.9}to{transform:translate(calc(-50% + var(--bubble-drift, 0px)),-80px);opacity:0}}.tools-section{padding:40px 24px 80px;max-width:1200px;margin:0 auto;position:relative}.tools-section h2{font-size:28px;font-weight:600;margin:0 0 32px;color:var(--text-primary);text-align:center;letter-spacing:.02em}.tools-carousel{position:relative;max-width:1120px;margin:0 auto;padding:0 32px}.tools-grid{display:block;overflow:hidden;padding:8px 2px 16px;margin:0;cursor:default;-webkit-user-select:none;user-select:none;touch-action:pan-y;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tools-track{display:grid;grid-auto-flow:column;grid-template-rows:repeat(3,minmax(0,1fr));grid-auto-columns:220px;column-gap:16px;row-gap:16px;transition:transform .25s ease;will-change:transform;align-content:start}.tools-track.is-jumping,.tools-track.is-dragging{transition:none}.tools-nav{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);box-shadow:var(--shadow-sm);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease}.tools-nav:hover{border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-50%) scale(1.05);box-shadow:var(--shadow-md)}.tools-nav-left{left:6px}.tools-nav-right{right:6px}.tool-card{width:100%;background:#ffffffeb;border:1px solid rgba(148,163,184,.4);border-radius:14px;padding:18px 18px 16px;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 24px #0f172a14;text-align:left;scroll-snap-align:start;min-height:96px;display:flex;align-items:center;position:relative;text-decoration:none}.tool-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px #0f172a29;border-color:#2196f3a6}.tool-card:focus-visible{outline:3px solid rgba(33,150,243,.35);outline-offset:3px;border-color:#2196f3cc}.tool-card-badge{position:absolute;top:10px;right:12px;padding:2px 8px;border-radius:999px;background:#22c55e26;color:#16a34a;border:1px solid rgba(34,197,94,.4);font-size:.68rem;font-weight:700;letter-spacing:.08em}.tool-card-content{display:flex;flex-direction:column;gap:6px}.tool-card h3{font-size:18px;font-weight:600;margin:0;color:var(--text-primary)}.tool-card p{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}@media (max-width: 768px){.hero{padding:40px 20px 30px}.hero-content{padding:28px 22px}.hero h1{font-size:32px}.hero p{font-size:16px;margin-bottom:30px}.hero-button{padding:14px 36px;font-size:16px}.tools-section{padding:30px 20px 60px}.tools-section h2{font-size:24px}.tools-carousel{padding:0 24px}.tools-track{grid-auto-columns:200px}.tool-card{padding:16px;min-height:100px}}@media (max-width: 480px){.hero-content{padding:24px 18px}.tools-track{grid-auto-columns:180px}.hero h1{font-size:28px}.hero p{font-size:15px}.hero-button{padding:12px 28px;font-size:15px}}html.dark-mode .hero-content{background:linear-gradient(140deg,#42a5f533,#42a5f50d);border-color:#42a5f540}html.dark-mode .tool-card{background:#1e293bbf;border-color:#94a3b82e}html.dark-mode .tool-card-badge{background:#22c55e2e;color:#86efac;border-color:#22c55e73}.wishpool-section{max-width:1100px;margin:40px auto 0;padding:0 20px 40px}.wishpool-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;text-align:center;justify-content:center;position:relative}.wishpool-header h2{margin:0;font-size:1.75rem;color:#0f172a;letter-spacing:.04em;position:relative;display:inline-flex;align-items:center;gap:8px;animation:wishpool-pulse 2.6s ease-in-out infinite}.wishpool-subtitle{margin:18px 0 0;color:#475569;font-size:.95rem;display:block}.wishpool-admin{position:absolute;right:0;top:0;display:inline-flex;align-items:center;gap:10px}.wishpool-admin-pill{background:#10b98126;color:#059669;border:1px solid rgba(16,185,129,.3);font-size:.75rem;padding:4px 8px;border-radius:999px;font-weight:700}.wishpool-admin-exit{border:1px solid rgba(239,68,68,.4);background:#ef444414;color:#b91c1c;border-radius:999px;padding:6px 10px;font-size:.8rem;cursor:pointer}.wishpool-header h2:after{content:"";position:absolute;left:50%;bottom:-14px;width:46px;height:4px;transform:translate(-50%);border-radius:999px;background:linear-gradient(90deg,#2563eb,#22c55e);box-shadow:0 4px 10px #2563eb40}@keyframes wishpool-pulse{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}.wishpool-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:14px;margin:14px 0 16px}.wishpool-form-row{margin-bottom:12px}.wishpool-form-row label{display:block}.wishpool-label{display:block;margin-bottom:6px;color:#4b5563;font-size:.9rem}.wishpool-hint{display:block;margin-top:6px;padding-left:12px;color:#9ca3af;font-size:.8rem}.wishpool-form input,.wishpool-form textarea{width:100%;box-sizing:border-box;border-radius:10px;border:1px solid #d1d5db;background:#fff;color:#111827;padding:10px 12px;outline:none}.wishpool-form input::placeholder,.wishpool-form textarea::placeholder{color:#9ca3af}.wishpool-form input:focus,.wishpool-form textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb33}.wishpool-actions{display:flex;justify-content:flex-end}.wishpool-submit{border:none;background:linear-gradient(135deg,#6366f1,#22c55e);color:#0b0f14;font-weight:700;border-radius:10px;padding:10px 14px;cursor:pointer;box-shadow:0 8px 18px #6366f12e}.wishpool-submit:disabled{opacity:.55;cursor:not-allowed}.wishpool-error{border:1px solid rgba(239,68,68,.35);background:#ef444414;border-radius:12px;padding:12px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:#991b1b}.wishpool-retry{border:1px solid #fecaca;background:#fff1f2;color:#991b1b;padding:8px 10px;border-radius:10px;cursor:pointer}.wishpool-list{display:grid;gap:12px}.wishpool-card{display:grid;grid-template-columns:1fr auto;gap:14px;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;position:relative}.wishpool-card-title{font-size:1.05rem;font-weight:700;color:#111827}.wishpool-card-body{margin-top:8px;color:#374151;line-height:1.45;white-space:pre-wrap}.wishpool-comments{margin-top:14px;padding-top:12px;border-top:1px solid rgba(148,163,184,.25)}.wishpool-comments-header{font-size:.9rem;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:8px}.wishpool-comments-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:#3b82f61f;color:#2563eb;font-size:.72rem}.wishpool-comments-form{display:grid;gap:8px;margin:10px 0 12px}.wishpool-comments-open{border:1px solid rgba(59,130,246,.25);background:#3b82f614;color:#1d4ed8;border-radius:10px;padding:6px 12px;cursor:pointer;font-size:.85rem;margin-top:8px;margin-bottom:10px;justify-self:flex-start}.wishpool-comments-actions{display:flex;gap:8px;align-items:center}.wishpool-comments-nickname,.wishpool-comments-input{width:100%;box-sizing:border-box;border-radius:10px;border:1px solid #d1d5db;background:#fff;color:#111827;padding:8px 10px;outline:none;font-size:.9rem}.wishpool-comments-input{resize:vertical}.wishpool-comments-submit{border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;font-weight:600;border-radius:10px;padding:8px 12px;cursor:pointer}.wishpool-comments-submit:disabled{opacity:.6;cursor:not-allowed}.wishpool-comments-cancel{border:1px solid rgba(148,163,184,.4);background:transparent;color:#64748b;border-radius:10px;padding:8px 12px;cursor:pointer;font-size:.85rem}.wishpool-comments-list{display:grid;gap:10px;margin-bottom:8px}.wishpool-comment{display:grid;grid-template-columns:8px 1fr auto;gap:10px;align-items:start}.wishpool-comment-line{width:2px;background:linear-gradient(180deg,#3b82f666,#22c55e4d);border-radius:999px;justify-self:center}.wishpool-comment-body{background:#94a3b81f;border-radius:12px;padding:8px 10px}.wishpool-comment-meta{display:flex;align-items:center;gap:8px;font-size:.78rem;color:#6b7280;flex-wrap:wrap}.wishpool-comment-meta span{color:#94a3b8}.wishpool-comment-text{margin-top:4px;color:#111827;font-size:.9rem;line-height:1.45;white-space:pre-wrap}.wishpool-comments-more{border:1px solid rgba(59,130,246,.25);background:#3b82f614;color:#1d4ed8;border-radius:999px;padding:6px 12px;cursor:pointer;font-size:.85rem}.wishpool-comments-more:disabled{opacity:.6;cursor:not-allowed}.wishpool-card-meta{margin-top:10px;color:#6b7280;font-size:.85rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.wishpool-card-meta-main{display:inline-flex;align-items:center;gap:6px}.wishpool-time-edit{border:1px solid rgba(59,130,246,.3);background:#3b82f614;color:#1d4ed8;border-radius:999px;padding:4px 8px;font-size:.72rem;cursor:pointer}.wishpool-time-edit--comment{padding:2px 6px;font-size:.7rem}.wishpool-time-editor{display:flex;align-items:center;gap:8px;margin-top:8px;flex-wrap:wrap}.wishpool-time-editor.is-comment{margin-top:6px}.wishpool-time-input{border:1px solid #d1d5db;border-radius:8px;padding:6px 8px;font-size:.8rem;background:#fff;color:#111827}.wishpool-time-save{border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.75rem}.wishpool-time-cancel{border:1px solid rgba(148,163,184,.4);background:transparent;color:#64748b;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.75rem}.wishpool-card-side{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;gap:12px;min-width:92px;position:absolute;top:14px;right:14px}.wishpool-votes{text-align:right}.wishpool-vote-count{font-size:1.4rem;font-weight:800;color:#111827}.wishpool-vote-label{font-size:.8rem;color:#6b7280;text-transform:uppercase;letter-spacing:.06em}.wishpool-vote-btn{width:100%;border:1px solid #d1d5db;background:#f8fafc;color:#111827;border-radius:10px;padding:10px 14px;min-width:52px;font-size:.95rem;cursor:pointer}.wishpool-vote-btn:disabled{opacity:.55;cursor:not-allowed}.wishpool-card-actions{display:flex;flex-direction:row;gap:8px;width:auto;margin-top:0}.wishpool-edit-votes-btn{border:1px solid rgba(59,130,246,.35);background:#3b82f61f;color:#1d4ed8;border-radius:10px;padding:8px 10px;cursor:pointer;font-size:.85rem}.wishpool-vote-editor{display:flex;align-items:center;gap:8px;margin-top:10px;justify-content:flex-end;flex-wrap:wrap}.wishpool-vote-input{width:90px;border:1px solid #d1d5db;border-radius:8px;padding:6px 8px;font-size:.8rem;background:#fff;color:#111827;text-align:center}.wishpool-vote-save{border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.75rem}.wishpool-vote-cancel{border:1px solid rgba(148,163,184,.4);background:transparent;color:#64748b;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.75rem}.wishpool-reset-btn{width:100%;border:1px solid rgba(239,68,68,.4);background:#ef444414;color:#b91c1c;border-radius:10px;padding:8px 10px;cursor:pointer;font-size:.85rem}.wishpool-reset-btn:disabled{opacity:.55;cursor:not-allowed}.wishpool-delete-btn{width:100%;border:1px solid rgba(239,68,68,.6);background:#ef444426;color:#b91c1c;border-radius:10px;padding:8px 10px;cursor:pointer;font-size:.85rem}.wishpool-delete-btn:disabled{opacity:.55;cursor:not-allowed}.wishpool-muted{color:#6b7280;padding:12px 0}.wishpool-card:hover{transform:translateY(-3px);box-shadow:0 10px 18px #0f172a14;border-color:#2563eb40}html.dark-mode .wishpool-header h2{color:#f8fafc;animation:wishpool-pulse 2.6s ease-in-out infinite}html.dark-mode .wishpool-subtitle{color:#f8fafcbf}html.dark-mode .wishpool-form{background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}html.dark-mode .wishpool-label{color:#ffffffbf}html.dark-mode .wishpool-hint{color:#ffffff8c}html.dark-mode .wishpool-form input,html.dark-mode .wishpool-form textarea{border:1px solid rgba(255,255,255,.11);background:#00000040;color:#fff}html.dark-mode .wishpool-form input::placeholder,html.dark-mode .wishpool-form textarea::placeholder{color:#ffffff8c}html.dark-mode .wishpool-form input:focus,html.dark-mode .wishpool-form textarea:focus{border-color:#6366f1cc;box-shadow:0 0 0 3px #6366f140}html.dark-mode .wishpool-error{color:#ffffffe6}html.dark-mode .wishpool-retry{border:1px solid rgba(255,255,255,.18);background:#ffffff0d;color:#fff}html.dark-mode .wishpool-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08)}html.dark-mode .wishpool-card:hover{box-shadow:0 10px 18px #00000059;border-color:#94a3b859}html.dark-mode .wishpool-card-title{color:#fff}html.dark-mode .wishpool-card-body{color:#ffffffc7}html.dark-mode .wishpool-card-meta{color:#ffffff73}html.dark-mode .wishpool-time-edit{border:1px solid rgba(59,130,246,.45);background:#3b82f638;color:#bfdbfe}html.dark-mode .wishpool-time-input{border:1px solid rgba(255,255,255,.12);background:#00000040;color:#fff}html.dark-mode .wishpool-time-cancel{border:1px solid rgba(148,163,184,.4);color:#e2e8f0cc}html.dark-mode .wishpool-comments{border-top:1px solid rgba(148,163,184,.15)}html.dark-mode .wishpool-comments-header{color:#f8fafc}html.dark-mode .wishpool-comments-count{background:#3b82f633;color:#bfdbfe}html.dark-mode .wishpool-comments-open{border:1px solid rgba(59,130,246,.4);background:#3b82f633;color:#bfdbfe}html.dark-mode .wishpool-comments-nickname,html.dark-mode .wishpool-comments-input{border:1px solid rgba(255,255,255,.12);background:#00000040;color:#fff}html.dark-mode .wishpool-comment-body{background:#0f172a99}html.dark-mode .wishpool-comment-text{color:#f8fafc}html.dark-mode .wishpool-comment-badge{background:#10b98133;color:#6ee7b7;border:1px solid rgba(16,185,129,.35)}html.dark-mode .wishpool-comment.is-admin .wishpool-comment-body{background:#05966933;border:1px solid rgba(16,185,129,.4)}html.dark-mode .wishpool-comment-delete{border:1px solid rgba(248,113,113,.5);background:#f8717126;color:#fecaca}html.dark-mode .wishpool-comments-more{border:1px solid rgba(59,130,246,.4);background:#3b82f633;color:#bfdbfe}html.dark-mode .wishpool-comments-cancel{border:1px solid rgba(148,163,184,.4);color:#e2e8f0cc}html.dark-mode .wishpool-vote-count{color:#fff}html.dark-mode .wishpool-vote-label{color:#ffffff8c}html.dark-mode .wishpool-vote-btn{border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#fff}html.dark-mode .wishpool-edit-votes-btn{border:1px solid rgba(59,130,246,.5);background:#3b82f633;color:#bfdbfe}html.dark-mode .wishpool-vote-input{border:1px solid rgba(255,255,255,.12);background:#00000040;color:#fff}html.dark-mode .wishpool-vote-cancel{border:1px solid rgba(148,163,184,.4);color:#e2e8f0cc}html.dark-mode .wishpool-reset-btn{border:1px solid rgba(248,113,113,.4);background:#f8717126;color:#fecaca}html.dark-mode .wishpool-delete-btn{border:1px solid rgba(248,113,113,.5);background:#f8717133;color:#fecaca}html.dark-mode .wishpool-admin-pill{background:#10b98126;color:#6ee7b7;border:1px solid rgba(16,185,129,.3)}html.dark-mode .wishpool-admin-exit{border:1px solid rgba(248,113,113,.4);background:#f871711f;color:#fecaca}html.dark-mode .wishpool-muted{color:#ffffffa6}@media (max-width: 720px){.wishpool-card{grid-template-columns:1fr;padding-top:46px}.wishpool-card-side{position:absolute;top:12px;right:12px;flex-direction:row;align-items:center;justify-content:flex-end;gap:12px;min-width:unset}.wishpool-vote-btn{width:auto}.wishpool-card-actions{flex-direction:row;width:auto}}.wishpool-comment-badge{background:#10b98126;color:#059669;border:1px solid rgba(16,185,129,.3);font-size:.7rem;padding:2px 6px;border-radius:999px;font-weight:700}.wishpool-comment.is-admin .wishpool-comment-body{background:#10b9811f;border:1px solid rgba(16,185,129,.3)}.wishpool-comment-delete{border:1px solid rgba(239,68,68,.4);background:#ef444414;color:#b91c1c;border-radius:10px;padding:6px 10px;cursor:pointer;font-size:.75rem;height:fit-content}.file-uploader{width:100%}.upload-area{border:2px dashed var(--border-color);border-radius:16px;padding:80px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary);position:relative}.upload-area:hover,.upload-area.dragging{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.upload-area h3{font-size:22px;font-weight:600;color:var(--text-primary);margin:16px 0 8px}.upload-area p{font-size:15px;color:var(--text-secondary);margin:0}.upload-icon{width:64px;height:64px;margin:0 auto 24px;color:var(--accent-color);display:flex;align-items:center;justify-content:center}.upload-icon svg{width:100%;height:100%}.upload-error{color:#d32f2f;font-size:14px;margin-top:16px;padding:12px;background:#d32f2f1a;border-radius:8px}.file-list{margin-top:24px}.file-list h4{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.file-list ul{list-style:none;padding:0;margin:0}.file-list li{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:12px;transition:all .2s ease}.file-list li:hover{border-color:var(--accent-color);box-shadow:var(--shadow-sm)}.file-icon{font-size:24px;flex-shrink:0}.file-name{flex:1;font-size:15px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:120px}.file-size{font-size:13px;color:var(--text-secondary);flex-shrink:0}.upload-progress-wrapper{display:flex;flex-direction:column;gap:4px;min-width:150px}.progress-bar{width:100%;height:6px;background:var(--border-color);border-radius:3px;overflow:hidden}.progress-bar-inner{height:100%;background:var(--accent-color);transition:width .3s ease}.upload-status-complete{font-size:12px;color:#4caf50;font-weight:500;text-align:center}.upload-status-uploading{font-size:12px;color:var(--text-secondary)}.download-btn-inline{flex-shrink:0}.download-btn-inline button{padding:8px 16px;font-size:13px;white-space:nowrap}.remove-btn{background:none;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;padding:8px 16px;font-size:13px;transition:all .2s ease;border-radius:6px;flex-shrink:0;white-space:nowrap}.remove-btn:hover{background:#d5443e1a;border-color:var(--accent-color);color:var(--accent-color)}@media (max-width: 768px){.upload-area{padding:60px 24px}.upload-area h3{font-size:18px}.upload-area p{font-size:14px}.upload-icon{width:48px;height:48px}.file-list li{flex-wrap:wrap;gap:8px}.file-name{width:100%;min-width:100%}.upload-progress-wrapper{width:100%;order:3}.download-btn-inline{width:100%;order:4}.download-btn-inline button{width:100%}.remove-btn{order:5;width:100%}}.conversion-options{width:100%}.options-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.option-group{display:flex;flex-direction:column;gap:10px}.option-label{font-size:14px;font-weight:600;color:var(--text-primary)}.format-select,.quality-input{padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:15px;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease;font-family:inherit}.format-select:focus,.quality-input:focus,.quality-slider:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f31a}.quality-input{width:100%}.quality-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary);margin-top:8px}.option-group label{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.convert-btn{width:100%;padding:14px 24px;background:var(--accent-color);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-md);margin-top:16px}.convert-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px #2196f34d}.convert-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.options-grid{grid-template-columns:1fr;gap:16px}.convert-btn{padding:14px 20px}}@media (max-width: 480px){.option-group label{font-size:13px}.format-select{font-size:14px;padding:10px 12px}.quality-labels{font-size:11px}.convert-btn{padding:12px 16px;font-size:15px}}.image-preview{width:100%}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;max-width:100%}.preview-item{border:1px solid var(--border-color);border-radius:8px;padding:12px;background:var(--bg-primary);transition:all .2s ease;overflow:hidden;display:flex;flex-direction:column}.preview-item:hover{border-color:var(--accent-color);box-shadow:var(--shadow-sm)}.preview-image{width:100%;height:240px;border-radius:6px;background:#fff;margin-bottom:12px;display:flex;align-items:center;justify-content:center;overflow:hidden}.preview-image img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.preview-info{font-size:13px;color:var(--text-secondary);text-align:center}.preview-name{font-weight:500;color:var(--text-primary);margin-bottom:4px;word-break:break-all;font-size:13px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}@media (max-width: 768px){.preview-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.preview-image{height:180px}.preview-info,.preview-name{font-size:12px}}@media (max-width: 480px){.preview-grid{grid-template-columns:repeat(2,1fr)}.preview-image{height:160px}}.download-btn-simple{background:#2196f3;color:#fff;border:none;cursor:pointer;padding:8px 16px;font-size:13px;transition:all .2s ease;border-radius:6px;flex-shrink:0;white-space:nowrap}.download-btn-simple:hover{background:#1976d2;transform:translateY(-1px);box-shadow:0 2px 8px #2196f34d}.download-btn-simple:active{transform:translateY(0)}.image-converter-tool{min-height:100vh;background:var(--bg-primary)}.tool-container{max-width:900px;margin:0 auto;padding:48px 24px 80px;display:grid;grid-template-columns:1fr;gap:24px;align-items:start}.tool-header{text-align:center;margin-bottom:40px;grid-column:1 / -1}.tool-header h1{font-size:38px;font-weight:700;margin:0 0 12px;color:var(--text-primary)}.tool-header p{font-size:17px;color:var(--text-secondary);margin:0;line-height:1.6}.download-section-top{max-width:800px;margin:0 auto 32px;animation:slideDown .4s ease-out}.download-section-top .tool-main-card{background:linear-gradient(135deg,#f5f7fa,#fff);border:2px solid var(--accent-color);box-shadow:0 4px 20px #d5443e26}.download-section-top .section-title{color:var(--accent-color);text-align:center;font-size:20px;margin-bottom:24px}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.tool-container.has-files{grid-template-columns:1fr 1fr;max-width:1400px}.tool-main-card{background:var(--bg-secondary);border-radius:16px;padding:48px 40px;box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.tool-section{margin-bottom:32px}.tool-section:last-child{margin-bottom:0}.section-title{font-size:18px;font-weight:600;margin:0 0 20px;color:var(--text-primary)}.divider{height:1px;background:var(--border-color);margin:32px 0}@media (max-width: 1024px){.tool-container,.tool-container.has-files{grid-template-columns:1fr;max-width:100%}}@media (max-width: 768px){.tool-container{padding:32px 16px 60px}.tool-header h1{font-size:28px}.tool-header p{font-size:15px}.tool-main-card{padding:32px 24px;border-radius:12px}.section-title{font-size:16px}}@media (max-width: 480px){.tool-container{padding:24px 12px 60px}.tool-header{margin-bottom:24px}.tool-header h1{font-size:24px}.tool-header p{font-size:14px}.tool-content,.tool-left-panel,.tool-right-panel{gap:16px}.tool-main-card{padding:20px 16px;border-radius:8px}.section-title{font-size:14px}.divider{margin:20px 0}}.tool-seo-section{max-width:800px;margin:48px auto 0;padding:32px 24px;border-top:1px solid rgba(255,255,255,.08);color:#ccc;line-height:1.8}.seo-block{margin-bottom:32px}.seo-block:last-child{margin-bottom:0}.seo-block h2{font-size:1.2rem;color:#e0e0e0;margin-bottom:12px;font-weight:600}.seo-block p{font-size:.95rem;color:#aaa;margin:0}.seo-features{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px}.seo-features li{font-size:.9rem;color:#aaa;padding:6px 0 6px 20px;position:relative}.seo-features li:before{content:"✓";position:absolute;left:0;color:#4fc3f7}.seo-steps{padding-left:20px;margin:0}.seo-steps li{font-size:.9rem;color:#aaa;padding:4px 0}.seo-steps li strong{color:#ddd}.seo-faq{margin:0}.seo-faq-item{margin-bottom:16px;padding:12px 16px;background:#ffffff08;border-radius:8px}.seo-faq-item:last-child{margin-bottom:0}.seo-faq-item dt{font-size:.95rem;color:#e0e0e0;font-weight:600;margin-bottom:6px}.seo-faq-item dd{font-size:.9rem;color:#aaa;margin:0}.seo-related{display:flex;flex-wrap:wrap;gap:8px}.seo-related-link{display:inline-block;padding:6px 14px;background:#4fc3f71a;color:#4fc3f7;border-radius:16px;text-decoration:none;font-size:.85rem;transition:background .2s}.seo-related-link:hover{background:#4fc3f733}@media (max-width: 600px){.tool-seo-section{padding:24px 16px;margin-top:32px}.seo-features{grid-template-columns:1fr}}.image-resize-crop-tool{min-height:100vh;background:var(--bg-primary)}.tool-header{text-align:center;margin-bottom:32px}.tool-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.tool-header p{font-size:16px;color:var(--text-secondary);margin-bottom:16px}.version-badge{display:inline-block;padding:6px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;font-size:13px;font-weight:600;box-shadow:0 2px 8px #667eea4d}.mode-selector{max-width:600px;margin:0 auto 32px;display:flex;gap:12px;background:var(--bg-secondary);padding:8px;border-radius:12px;border:1px solid var(--border-color)}.mode-btn{flex:1;padding:14px 24px;background:none;border:none;border-radius:8px;font-size:16px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.mode-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.mode-btn.active{background:var(--accent-color);color:#fff;box-shadow:var(--shadow-md)}.upload-section{max-width:800px;margin:0 auto}.upload-icon{width:64px;height:64px;margin:0 auto 24px;color:var(--accent-color)}.upload-area h3{font-size:22px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.upload-area p{font-size:15px;color:var(--text-secondary)}.tool-content{display:grid;grid-template-columns:1fr;gap:24px;max-width:1400px;margin:0 auto}.tool-content.has-file{grid-template-columns:1.2fr 1fr}.tool-left-panel,.tool-right-panel{display:flex;flex-direction:column;gap:24px}.preview-section h3,.settings-section h3{font-size:18px;font-weight:600;margin-bottom:20px;color:var(--text-primary)}.image-preview-container{position:relative;width:100%;min-height:400px;max-height:600px;background:#f5f5f5;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:20px;-webkit-user-select:none;user-select:none}.preview-image{max-width:100%;max-height:600px;width:auto;height:auto;object-fit:contain;display:block;pointer-events:none}.crop-overlay{position:absolute;border:3px solid var(--accent-color);background:#2196f326;box-shadow:0 0 0 9999px #0009;z-index:10;pointer-events:auto;cursor:move;touch-action:none}.crop-overlay:active{cursor:grabbing}.crop-handle{position:absolute;width:14px;height:14px;background:#fff;border:3px solid var(--accent-color);border-radius:50%;z-index:20;transition:all .15s ease;box-shadow:0 2px 6px #0000004d;touch-action:none}.crop-handle:hover{transform:scale(1.4);background:var(--accent-color);box-shadow:0 3px 10px #2196f380}.crop-handle:active{transform:scale(1.2)}.crop-handle-nw{top:-6px;left:-6px;cursor:nw-resize}.crop-handle-ne{top:-6px;right:-6px;cursor:ne-resize}.crop-handle-sw{bottom:-6px;left:-6px;cursor:sw-resize}.crop-handle-se{bottom:-6px;right:-6px;cursor:se-resize}.crop-grid{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.crop-grid-line{position:absolute;background:#ffffff80}.crop-grid-v1{left:33.333%;top:0;bottom:0;width:1px}.crop-grid-v2{left:66.666%;top:0;bottom:0;width:1px}.crop-grid-h1{top:33.333%;left:0;right:0;height:1px}.crop-grid-h2{top:66.666%;left:0;right:0;height:1px}.file-info{background:var(--bg-primary);padding:16px;border-radius:8px;margin-bottom:16px}.file-info p{margin:8px 0;font-size:14px;color:var(--text-secondary)}.file-info strong{color:var(--text-primary);font-weight:600}.change-file-btn{width:100%;padding:12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease}.change-file-btn:hover{border-color:var(--accent-color);color:var(--accent-color);background:#2196f30d}.settings-section{padding:0}.input-group{margin-bottom:20px}.input-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.input-group input[type=number],.input-group select{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:15px;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.input-group input[type=number]:focus,.input-group select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f31a}.checkbox-group{margin:20px 0}.checkbox-group label{display:flex;align-items:center;gap:8px;font-size:15px;color:var(--text-primary);cursor:pointer}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-color)}.crop-info{background:var(--bg-primary);padding:16px;border-radius:8px;margin-bottom:20px}.crop-info p{color:var(--text-secondary);font-size:14px;margin-bottom:12px}.crop-details{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}.crop-details p{background:var(--bg-secondary);padding:8px 12px;border-radius:6px;font-size:13px;margin:0}.divider{height:1px;background:var(--border-color);margin:24px 0}.quality-slider{width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,#2196F3 0%,#2196F3 var(--value, 50%),#e0e0e0 var(--value, 50%),#e0e0e0 100%);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:background .2s ease,opacity .2s ease;cursor:pointer}.quality-slider:disabled{opacity:.4;cursor:not-allowed;background:linear-gradient(to right,#999 0%,#999 var(--value, 50%),#e0e0e0 var(--value, 50%),#e0e0e0 100%)}.quality-note{font-size:12px;color:var(--text-secondary);font-weight:400;margin-left:8px}.quality-slider::-webkit-slider-runnable-track{width:100%;height:6px;border-radius:3px;background:transparent}.quality-slider::-moz-range-track{width:100%;height:6px;border-radius:3px;background:transparent}.quality-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent-color);cursor:pointer;transition:all .2s ease;margin-top:-6px;box-shadow:0 2px 4px #0003}.quality-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 3px 8px #2196f366}.quality-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--accent-color);cursor:pointer;border:none;transition:all .2s ease;box-shadow:0 2px 4px #0003}.quality-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 3px 8px #2196f366}.download-btn{width:100%;padding:16px 24px;background:var(--accent-color);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-md);margin-top:16px}.download-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px #2196f34d}.download-btn:active{transform:translateY(0)}@media (max-width: 1024px){.tool-content.has-file{grid-template-columns:1fr}}@media (max-width: 768px){.mode-selector{margin-bottom:24px}.mode-btn{padding:12px 16px;font-size:14px}.upload-area{padding:60px 24px}.upload-area h3{font-size:18px}.image-preview-container,.preview-image{max-height:300px}}@media (max-width: 480px){.mode-selector{flex-direction:column;gap:8px}.upload-area{padding:40px 20px}.upload-area h3{font-size:16px}.upload-icon{width:48px;height:48px}.crop-details{grid-template-columns:1fr}}.compress-tool-container{min-height:100vh;background:var(--bg-primary);padding:80px 20px}.compress-tool-content{width:100%;max-width:1200px;margin:0 auto}.compress-title{font-size:2.5rem;color:var(--text-primary);text-align:center;margin-bottom:10px;display:flex;align-items:center;justify-content:center;gap:15px}.compress-icon{font-size:3rem}.compress-subtitle{text-align:center;color:var(--text-secondary);font-size:1.1rem;margin-bottom:40px}.compress-upload-area{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:16px;padding:80px 40px;text-align:center;cursor:pointer;transition:all .3s ease}.compress-upload-area:hover{background:#2196f30d;border-color:var(--accent-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.upload-text{font-size:1.25rem;color:var(--text-primary);margin-bottom:10px}.upload-hint{color:var(--text-secondary);font-size:.95rem}.compress-processing-area{background:var(--bg-secondary);border-radius:20px;padding:40px;border:1px solid var(--border-color)}.compress-progress-container{margin-bottom:30px}.compress-progress-bar{width:100%;height:30px;background:var(--border-color);border-radius:15px;overflow:hidden;position:relative}.compress-progress-fill{height:100%;background:linear-gradient(90deg,#2196f3,#64b5f6);transition:width .3s ease;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;border-radius:15px}.compress-progress-text{text-align:center;color:var(--text-primary);margin-top:10px;font-size:1.1rem;font-weight:600}.compress-error{background:#ef44441a;border:2px solid rgba(239,68,68,.5);border-radius:10px;padding:20px;margin-bottom:30px;color:#fca5a5;display:flex;align-items:center;gap:10px}.compress-preview-container{display:grid;grid-template-columns:1fr auto 1fr;gap:30px;margin-bottom:30px;align-items:center}.compress-preview-box{background:var(--bg-secondary);border-radius:15px;padding:25px;border:2px solid rgba(33,150,243,.3)}.preview-title{color:var(--text-primary);font-size:1.3rem;margin-bottom:20px;text-align:center;font-weight:600}.preview-image-wrapper{width:100%;background:var(--bg-primary);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;border:1px solid var(--border-color);padding:15px}.preview-image{max-width:100%;width:auto;height:auto;object-fit:contain;display:block}.preview-info{text-align:center}.info-label{color:var(--text-secondary);font-size:.9rem;margin-bottom:5px;margin-top:10px}.info-value{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:10px}.size-original{color:#fbbf24}.size-compressed{color:#34d399}.size-saved{color:#2196f3}.compress-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.arrow-icon{font-size:3rem;color:#2196f3}.arrow-text{color:var(--text-secondary);font-size:.9rem;text-align:center;line-height:1.5}.arrow-text strong{color:#2196f3;font-size:1.3rem}.compress-actions{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.btn-download,.btn-reset{padding:15px 40px;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:10px}.btn-download{background:linear-gradient(135deg,#2196f3,#64b5f6);color:#fff}.btn-download:hover{transform:translateY(-3px);box-shadow:0 10px 25px #2196f366}.btn-reset{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color)}.btn-reset:hover{background:var(--bg-primary);transform:translateY(-3px);box-shadow:var(--shadow-md)}.btn-icon{font-size:1.3rem}@media (max-width: 1024px){.compress-preview-container{grid-template-columns:1fr;gap:20px}.compress-arrow{transform:rotate(90deg)}}@media (max-width: 768px){.compress-title{font-size:2rem}.compress-icon{font-size:2.5rem}.compress-upload-area{padding:60px 30px}.upload-icon{font-size:4rem}.upload-text{font-size:1.2rem}.compress-processing-area{padding:25px}.preview-image-wrapper{padding:10px}.compress-actions{flex-direction:column}.btn-download,.btn-reset{width:100%;justify-content:center}}@media (max-width: 480px){.compress-title{font-size:1.5rem;flex-direction:column;gap:5px}.compress-subtitle{font-size:.9rem}.compress-upload-area{padding:40px 20px}.upload-text{font-size:1rem}.upload-hint{font-size:.85rem}}.image-exif-cleaner{max-width:1180px;margin:0 auto;padding:40px 20px 80px;color:#f4f1e8}.image-exif-cleaner__hero{margin-bottom:24px}.image-exif-cleaner__hero h1{margin:0 0 12px;font-size:clamp(2rem,4vw,3.2rem)}.image-exif-cleaner__hero p{margin:0;max-width:720px;color:#d5d1c4;line-height:1.6}.image-exif-cleaner__panel{background:linear-gradient(180deg,#14181ef2,#222730eb);border:1px solid rgba(255,255,255,.08);border-radius:28px;padding:24px;box-shadow:0 24px 80px #00000047}.image-exif-cleaner__dropzone{width:100%;border:2px dashed rgba(238,198,67,.4);border-radius:24px;padding:36px 24px;background:#ffffff08;color:inherit;display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;cursor:pointer}.image-exif-cleaner__dropzone.is-dragging{border-color:#eec643;background:#eec6431a}.image-exif-cleaner__drop-icon{font-size:2rem}.image-exif-cleaner__toolbar{margin-top:20px;display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap}.image-exif-cleaner__toolbar p{margin:4px 0 0;color:#b9c0cc}.image-exif-cleaner__actions{display:flex;gap:12px;flex-wrap:wrap}.image-exif-cleaner__actions button,.image-exif-cleaner__buttons button{border:none;border-radius:999px;padding:10px 16px;font-weight:700;cursor:pointer;background:#eec643;color:#201d15}.image-exif-cleaner__buttons .is-muted{background:#ffffff1a;color:#f4f1e8}.image-exif-cleaner__actions button:disabled,.image-exif-cleaner__buttons button:disabled{opacity:.45;cursor:not-allowed}.image-exif-cleaner__error,.image-exif-cleaner__empty{margin-top:18px;border-radius:18px;padding:14px 16px}.image-exif-cleaner__error{background:#c9343429;color:#ffd4d4}.image-exif-cleaner__empty{background:#ffffff0a;color:#d5d1c4}.image-exif-cleaner__grid{margin-top:22px;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}.image-exif-cleaner__card{overflow:hidden;border-radius:22px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.image-exif-cleaner__card img{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block;background:#0d1117}.image-exif-cleaner__card-body{padding:16px}.image-exif-cleaner__meta h2{margin:0 0 4px;font-size:1rem;word-break:break-word}.image-exif-cleaner__meta p{margin:0 0 12px;color:#b9c0cc}.image-exif-cleaner__status{border-radius:16px;padding:12px;background:#ffffff0d;min-height:88px}.image-exif-cleaner__status.is-clean{background:#48bb7829}.image-exif-cleaner__status strong,.image-exif-cleaner__status span{display:block}.image-exif-cleaner__status span{margin-top:6px;color:#d5d1c4;line-height:1.5}.image-exif-cleaner__buttons{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}@media (max-width: 720px){.image-exif-cleaner{padding:24px 14px 56px}.image-exif-cleaner__panel{padding:18px}.image-exif-cleaner__dropzone{padding:28px 18px}}.image-watermark-tool{display:flex;flex-direction:column;gap:24px;color:#e8edf4}.image-watermark-tool__hero,.image-watermark-tool__panel{background:linear-gradient(145deg,#0d1826f0,#142234e0);border:1px solid rgba(255,255,255,.08);border-radius:24px;box-shadow:0 24px 60px #0208143d}.image-watermark-tool__hero{display:flex;justify-content:space-between;gap:24px;padding:28px}.image-watermark-tool__hero h1{margin:0 0 10px;font-size:clamp(2rem,4vw,2.8rem)}.image-watermark-tool__hero p{margin:0;max-width:700px;color:#e8edf4c7;line-height:1.6}.image-watermark-tool__hero-stats{min-width:220px;display:flex;flex-direction:column;gap:10px;padding:18px 20px;border-radius:18px;background:#ffffff0d}.image-watermark-tool__panel{padding:28px}.image-watermark-tool__dropzone{width:100%;display:flex;flex-direction:column;gap:10px;align-items:center;justify-content:center;padding:32px 20px;border-radius:22px;border:1.5px dashed rgba(135,183,255,.45);background:radial-gradient(circle at top,rgba(90,159,255,.18),transparent 45%),#070e198c;color:inherit;cursor:pointer}.image-watermark-tool__dropzone.is-dragging{transform:translateY(-1px);border-color:#ffd061f2;background:radial-gradient(circle at top,rgba(255,208,97,.22),transparent 45%),#070e19b3}.image-watermark-tool__drop-icon{font-size:2rem}.image-watermark-tool__controls{margin-top:22px;display:flex;flex-direction:column;gap:18px}.image-watermark-tool__mode-switch{display:inline-flex;width:fit-content;gap:10px;padding:6px;border-radius:999px;background:#ffffff0d}.image-watermark-tool__mode-switch button,.image-watermark-tool__actions button,.image-watermark-tool__card-actions button,.image-watermark-tool__logo-picker button{border:none;border-radius:999px;cursor:pointer;transition:transform .16s ease,opacity .16s ease,background .16s ease}.image-watermark-tool__mode-switch button{padding:10px 16px;background:transparent;color:#e8edf4c7}.image-watermark-tool__mode-switch button.is-active{background:linear-gradient(135deg,#ffd061,#ff9248);color:#0a1320;font-weight:700}.image-watermark-tool__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.image-watermark-tool__grid label,.image-watermark-tool__logo-picker,.image-watermark-tool__logo-preview{display:flex;flex-direction:column;gap:8px;padding:16px;border-radius:18px;background:#ffffff0d}.image-watermark-tool__grid input[type=text],.image-watermark-tool__grid select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:#060e18d1;color:inherit}.image-watermark-tool__grid input[type=range]{width:100%}.image-watermark-tool__checkbox{justify-content:center}.image-watermark-tool__checkbox input{margin-right:8px}.image-watermark-tool__color-row{display:flex;align-items:center;gap:12px}.image-watermark-tool__color-row input[type=color]{width:56px;height:40px;padding:0;border:none;background:transparent}.image-watermark-tool__logo-picker button,.image-watermark-tool__actions button,.image-watermark-tool__card-actions button{padding:12px 18px;font-weight:700}.image-watermark-tool__logo-picker button,.image-watermark-tool__actions button,.image-watermark-tool__card-actions button:first-child{background:linear-gradient(135deg,#ffd061,#ff9248);color:#09111d}.image-watermark-tool__logo-preview{align-items:center;justify-content:center;min-height:132px}.image-watermark-tool__logo-preview img{max-width:100%;max-height:100px;object-fit:contain}.image-watermark-tool__actions{display:flex;gap:12px}.image-watermark-tool__actions .is-secondary,.image-watermark-tool__card-actions .is-secondary{background:#ffffff14;color:#f2f5fa}.image-watermark-tool__card-actions .is-ghost{background:transparent;color:#e8edf4b8;border:1px solid rgba(255,255,255,.12)}.image-watermark-tool__error,.image-watermark-tool__empty{margin-top:18px;padding:16px 18px;border-radius:16px}.image-watermark-tool__error{background:#ff62621f;border:1px solid rgba(255,98,98,.32);color:#ffb6b6}.image-watermark-tool__empty{background:#ffffff0a;color:#e8edf4c2}.image-watermark-tool__cards{margin-top:24px;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}.image-watermark-tool__card{overflow:hidden;border-radius:22px;background:#040a13a8;border:1px solid rgba(255,255,255,.08)}.image-watermark-tool__preview{aspect-ratio:4 / 3;background:linear-gradient(45deg,rgba(255,255,255,.04) 25%,transparent 25%,transparent 75%,rgba(255,255,255,.04) 75%),linear-gradient(45deg,rgba(255,255,255,.04) 25%,transparent 25%,transparent 75%,rgba(255,255,255,.04) 75%);background-position:0 0,12px 12px;background-size:24px 24px}.image-watermark-tool__preview img{width:100%;height:100%;object-fit:contain;display:block}.image-watermark-tool__card-body{display:flex;flex-direction:column;gap:14px;padding:16px}.image-watermark-tool__meta h2,.image-watermark-tool__status strong{margin:0}.image-watermark-tool__meta p,.image-watermark-tool__status span{margin:4px 0 0;color:#e8edf4b8}.image-watermark-tool__status{padding:12px 14px;border-radius:16px;background:#ffffff0a}.image-watermark-tool__status.is-已完成{background:#58c4781f}.image-watermark-tool__status.is-失敗{background:#ff62621f}.image-watermark-tool__card-actions{display:flex;gap:10px;flex-wrap:wrap}.image-watermark-tool__actions button:disabled,.image-watermark-tool__card-actions button:disabled,.image-watermark-tool__logo-picker button:disabled{opacity:.55;cursor:not-allowed;transform:none}.image-watermark-tool__actions button:not(:disabled):hover,.image-watermark-tool__card-actions button:not(:disabled):hover,.image-watermark-tool__logo-picker button:not(:disabled):hover,.image-watermark-tool__mode-switch button:not(:disabled):hover{transform:translateY(-1px)}@media (max-width: 900px){.image-watermark-tool__hero,.image-watermark-tool__grid{grid-template-columns:1fr}.image-watermark-tool__hero{flex-direction:column}}@media (max-width: 640px){.image-watermark-tool__panel,.image-watermark-tool__hero{padding:20px;border-radius:20px}.image-watermark-tool__actions,.image-watermark-tool__card-actions{flex-direction:column}.image-watermark-tool__actions button,.image-watermark-tool__card-actions button{width:100%}}.image-hosting-tool{max-width:1100px;margin:0 auto;padding:40px 24px 80px}.hosting-header{text-align:center;margin-bottom:32px}.hosting-header h2{font-size:32px;margin-bottom:10px;color:var(--text-primary)}.hosting-header p{color:var(--text-secondary)}.hosting-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:24px;box-shadow:var(--shadow-md);margin-bottom:24px}.hosting-tabs{display:flex;gap:12px;margin-bottom:20px}.hosting-tab{flex:1;padding:12px 16px;border-radius:12px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);cursor:pointer;font-weight:600}.hosting-tab.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.hosting-form{display:grid;gap:16px}.hosting-form label{display:grid;gap:8px;color:var(--text-primary);font-weight:600}.hosting-form input{padding:12px 14px;border-radius:10px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary)}.hosting-auth-title h3{margin:0 0 6px;font-size:20px}.hosting-auth-title p{margin:0 0 16px;color:var(--text-secondary)}.hosting-link{border:none;background:transparent;color:var(--accent-color);font-weight:600;cursor:pointer;padding:0;text-align:left}.hosting-primary,.hosting-secondary,.hosting-danger{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 16px;border-radius:10px;border:none;cursor:pointer;font-weight:600;text-decoration:none}.hosting-primary{background:var(--accent-color);color:#fff}.hosting-secondary{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.hosting-danger{background:#f44336;color:#fff}.hosting-error{padding:10px 12px;border-radius:10px;background:#f443361a;color:#f44336;font-weight:600;margin-top:12px}.hosting-notice{padding:10px 12px;border-radius:10px;background:#4caf5026;color:#4caf50;font-weight:600;margin-top:12px}.hosting-upgrade{background:#ffc1071f;border-color:#ffc10766}.hosting-upgrade-text{color:var(--text-primary);font-weight:600;line-height:1.6}.hosting-upgrade-text a{color:var(--accent-color);text-decoration:none;word-break:break-all}.hosting-muted{color:var(--text-secondary)}.hosting-account{display:flex;justify-content:space-between;align-items:center;gap:12px}.hosting-account-actions{display:flex;gap:10px;flex-wrap:wrap}.hosting-guest-banner{display:flex;justify-content:space-between;align-items:center;gap:16px}.hosting-guest-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.hosting-usage{color:var(--text-secondary);font-weight:600;font-size:13px}.hosting-quota{display:grid;gap:10px;margin-bottom:16px}.hosting-quota-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;color:var(--text-secondary);font-weight:600;font-size:13px}.hosting-quota-title{display:inline-flex;align-items:center;gap:6px}.hosting-tooltip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;border:1px solid var(--border-color);font-size:12px;color:var(--text-secondary);cursor:help}.hosting-tooltip:after{content:attr(data-tooltip);position:absolute;left:50%;bottom:130%;transform:translate(-50%) translateY(6px);background:#1f1f1f;color:#fff;padding:8px 10px;border-radius:8px;font-size:12px;line-height:1.4;min-width:180px;max-width:260px;text-align:left;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:5}.hosting-tooltip:before{content:"";position:absolute;left:50%;bottom:120%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1f1f1f;opacity:0;transition:opacity .15s ease;pointer-events:none;z-index:4}.hosting-tooltip:hover:after,.hosting-tooltip:focus-visible:after,.hosting-tooltip:hover:before,.hosting-tooltip:focus-visible:before{opacity:1;transform:translate(-50%) translateY(0)}.hosting-quota-remaining{color:var(--text-secondary);font-size:13px}.hosting-account-info{display:grid;gap:6px}.hosting-account-label{font-weight:700}.hosting-section-title{font-size:18px;font-weight:700;margin-bottom:16px}.hosting-expiry{display:grid;gap:8px;margin-bottom:16px}.hosting-expiry-inline{margin-bottom:0}.hosting-expiry-inline .hosting-expiry-controls{gap:8px}.hosting-expiry-label{display:grid;gap:8px;font-weight:600;color:var(--text-primary)}.hosting-expiry-controls{display:flex;gap:12px;flex-wrap:wrap}.hosting-expiry select,.hosting-expiry input{padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary)}.hosting-upload-area{border:2px dashed var(--border-color);border-radius:16px;padding:28px;text-align:center;cursor:pointer;display:grid;gap:12px;color:var(--text-secondary);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease}.hosting-upload-area:hover{border-color:var(--accent-color);background:#2196f314;color:var(--text-primary);box-shadow:0 0 0 2px #2196f326}.hosting-upload-icon{font-size:32px}.hosting-file-card{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px;border-radius:12px;border:1px solid var(--border-color)}.hosting-file-name{font-weight:700}.hosting-file-size{color:var(--text-secondary);margin-top:4px}.hosting-file-actions{display:flex;gap:10px;align-items:center}.hosting-progress{display:flex;align-items:center;gap:12px;margin-top:16px}.hosting-qr{display:flex;align-items:center;gap:16px;margin-top:16px;flex-wrap:wrap}.hosting-qr-side{margin-top:0}.hosting-qr-preview{width:140px;height:140px;padding:8px;border-radius:12px;border:1px solid var(--border-color);background:#fff;display:flex;align-items:center;justify-content:center}.hosting-qr-preview img{max-width:100%;max-height:100%}.hosting-qr-info{display:grid;gap:10px}.hosting-qr-title{font-weight:700;color:var(--text-primary)}.hosting-progress-bar{flex:1;height:10px;border-radius:999px;background:#00000014;overflow:hidden}.hosting-progress-bar div{height:100%;background:var(--accent-color);transition:width .2s ease}.hosting-result{margin-top:16px;display:grid;gap:12px}.hosting-result-body{display:flex;align-items:flex-start;gap:24px;justify-content:space-between;flex-wrap:wrap}.hosting-result-info{flex:1;min-width:220px;display:grid;gap:12px}.hosting-result-title{font-weight:700;color:var(--accent-color)}.hosting-result-row{display:grid;gap:6px}.hosting-result-row a{color:var(--accent-color);word-break:break-all}.hosting-result-actions{display:flex;gap:10px;flex-wrap:wrap}.hosting-list{display:grid;gap:12px;margin-top:12px}.hosting-list-item{display:flex;justify-content:space-between;gap:16px;padding:16px;border-radius:12px;border:1px solid var(--border-color);align-items:center}.hosting-list-thumb{width:64px;height:64px;border-radius:10px;border:1px solid var(--border-color);background:#ffffff0a;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;color:var(--text-secondary);font-size:12px;text-align:center;padding:6px}.hosting-list-thumb img{width:100%;height:100%;object-fit:cover;display:block}.hosting-list-main{flex:1;min-width:0}.hosting-list-main a{color:var(--text-primary);font-weight:600;word-break:break-all}.hosting-list-meta{display:flex;gap:16px;color:var(--text-secondary);font-size:13px;margin-top:6px;flex-wrap:wrap}.hosting-list-actions{display:flex;gap:10px;flex-wrap:nowrap;flex-shrink:0;align-items:center}.hosting-list-actions .hosting-secondary,.hosting-list-actions .hosting-danger{white-space:nowrap}.hosting-list-item.expired{opacity:.8}.hosting-expired{color:#f44336;font-weight:700}.hosting-expired-link{color:#f44336}.hosting-restore-hint{color:var(--text-secondary);font-weight:600}@media (max-width: 768px){.image-hosting-tool{padding:32px 16px 60px}.hosting-file-card,.hosting-list-item,.hosting-account,.hosting-guest-banner{flex-direction:column;align-items:flex-start}.hosting-file-actions,.hosting-list-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.hosting-result-body{flex-direction:column;align-items:flex-start}}.image-host-pricing{max-width:1200px;margin:0 auto;padding:40px 24px 90px;color:var(--text-primary)}.pricing-hero{text-align:center;margin-bottom:36px}.pricing-label{text-transform:uppercase;letter-spacing:.2em;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:12px}.pricing-hero h2{font-size:32px;margin:0 0 12px}.pricing-hero p{margin:0 auto;max-width:640px;color:var(--text-secondary)}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:40px}.pricing-card{position:relative;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:18px;padding:24px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:18px}.pricing-card.featured{border-color:var(--accent-color);box-shadow:0 0 0 1px #4f92ff66,var(--shadow-md)}.pricing-badge{position:absolute;top:18px;right:18px;background:var(--accent-color);color:#fff;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700}.pricing-card-header h3{margin:0 0 6px;font-size:22px}.pricing-card-header p{margin:0;color:var(--text-secondary);font-size:14px}.pricing-price{display:flex;align-items:baseline;gap:6px}.pricing-amount{font-size:32px;font-weight:700;color:var(--text-primary)}.pricing-unit{font-size:14px;color:var(--text-secondary)}.pricing-features{list-style:none;margin:0;padding:0;display:grid;gap:10px}.pricing-features li{display:flex;justify-content:space-between;color:var(--text-secondary)}.pricing-features strong{color:var(--text-primary);font-weight:600}.pricing-cta{margin-top:auto;border-radius:12px;border:none;padding:12px 16px;background:var(--accent-color);color:#fff;font-weight:600;cursor:pointer}.pricing-compare{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:18px 16px;display:grid;gap:12px;box-shadow:var(--shadow-md)}.pricing-compare-header,.pricing-compare-row{display:grid;grid-template-columns:minmax(120px,1.2fr) repeat(4,minmax(90px,1fr));gap:12px;align-items:center}.pricing-compare-header{font-weight:700;color:var(--text-primary);padding-bottom:6px;border-bottom:1px solid var(--border-color)}.pricing-compare-row{color:var(--text-secondary);font-size:14px}.pricing-compare-label{color:var(--text-primary);font-weight:600}.pricing-contact{margin-top:26px;text-align:center;color:var(--text-secondary)}.pricing-contact a{color:var(--accent-color);text-decoration:none;font-weight:600}@media (max-width: 720px){.pricing-hero h2{font-size:26px}.pricing-compare-header,.pricing-compare-row{grid-template-columns:1fr;gap:6px}.pricing-compare-header span:not(:first-child){display:none}.pricing-compare-row{border-top:1px solid var(--border-color);padding-top:8px}}.json-to-csv-tool{max-width:900px;margin:0 auto;padding:20px}.tool-content{background:var(--bg-primary);border-radius:12px;padding:30px;box-shadow:var(--shadow-md)}.upload-area{border:2px dashed var(--border-color);border-radius:16px;padding:80px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary)}.upload-area:hover{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.upload-icon{font-size:3rem;margin-bottom:24px}.upload-text{font-size:1.25rem;color:var(--text-primary);margin-bottom:10px;font-weight:500}.upload-hint{color:var(--text-secondary);font-size:.95rem;margin:4px 0}.file-preview{text-align:center}.file-info-card{display:flex;align-items:center;justify-content:center;gap:20px;padding:20px;background:var(--bg-secondary);border-radius:12px;margin-bottom:25px}.file-icon{font-size:3rem}.file-details h3{margin:0 0 5px;color:var(--text-primary);font-size:1.1rem}.file-size{color:var(--text-secondary);margin:0}.conversion-options{margin:25px 0;padding:20px;background:var(--bg-secondary);border-radius:8px}.option-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:1rem}.option-label input[type=checkbox]{margin-top:3px;width:18px;height:18px;cursor:pointer}.option-label span{color:var(--text-primary)}.option-help{display:block;color:var(--text-secondary);font-size:.85rem;margin-top:5px;margin-left:28px}.split-options{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color)}.split-input-row{margin-top:12px;display:grid;grid-template-columns:auto 140px 1fr;align-items:center;gap:10px}.split-label{color:var(--text-primary);font-weight:500}.split-input{padding:8px 10px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem}.split-input:disabled{opacity:.6;cursor:not-allowed}.split-help{color:var(--text-secondary);font-size:.85rem}.action-buttons{display:flex;gap:15px;justify-content:center;margin-top:25px}.btn-primary,.btn-secondary,.btn-download{padding:12px 30px;font-size:1rem;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .3s ease}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #2196f34d}.btn-download{background:#4caf50;color:#fff}.btn-download:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.converting-status{margin-top:25px}.progress-bar{width:100%;height:30px;background:var(--bg-secondary);border-radius:15px;overflow:hidden;margin-bottom:10px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),var(--accent-hover));transition:width .3s ease;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:500}.progress-text{text-align:center;color:var(--text-secondary);font-size:.9rem}.conversion-result{text-align:center}.success-icon{font-size:4rem;margin-bottom:20px}.conversion-result h3{color:#4caf50;margin-bottom:25px;font-size:1.5rem}.result-info{background:var(--bg-secondary);border-radius:12px;padding:25px;margin-bottom:25px;text-align:left}.result-item{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-color)}.result-item:last-child{border-bottom:none}.result-label{color:var(--text-secondary);font-weight:500}.result-value{color:var(--text-primary);font-weight:600}.split-results{margin-top:10px}.split-list{display:grid;gap:12px;margin-bottom:20px}.split-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;background:var(--bg-secondary);border-radius:10px}.split-item-info{display:flex;flex-direction:column;text-align:left;gap:6px}.split-item-name{color:var(--text-primary);font-weight:600}.split-item-meta{color:var(--text-secondary);font-size:.9rem}.split-zip-hint{color:var(--text-secondary);margin-bottom:16px;text-align:center}.error-message{background:#ffebee;color:#c62828;padding:15px 20px;border-radius:8px;margin-top:20px;display:flex;align-items:center;gap:10px}.error-icon{font-size:1.5rem}html.dark-mode .upload-area{background:#353535}html.dark-mode .upload-area:hover{background:#404040}html.dark-mode .file-info-card,html.dark-mode .conversion-options,html.dark-mode .result-info,html.dark-mode .split-item{background:#353535}html.dark-mode .btn-secondary{background:#404040;color:#fff;border-color:#555}html.dark-mode .btn-secondary:hover{background:#505050}html.dark-mode .progress-bar{background:#404040}html.dark-mode .error-message{background:#5a1f1f;color:#ffcdd2}@media (max-width: 768px){.json-to-csv-tool{padding:15px}.tool-content{padding:20px}.tool-header h2{font-size:1.5rem}.upload-area{padding:40px 15px}.upload-icon{font-size:3rem}.action-buttons{flex-direction:column}.btn-primary,.btn-secondary,.btn-download{width:100%}.result-item{flex-direction:column;gap:5px}.result-value{text-align:left}.split-input-row{grid-template-columns:1fr;align-items:stretch}.split-item{flex-direction:column;align-items:flex-start}}.json-format-tool{max-width:1180px;margin:0 auto;padding:20px}.json-format-tool .tool-header{text-align:center;margin-bottom:28px}.json-format-tool .tool-header h2{font-size:2rem;color:var(--text-primary);margin-bottom:10px}.json-format-tool .subtitle{color:var(--text-secondary);font-size:1rem}.json-format-shell{background:var(--bg-primary);border-radius:18px;padding:28px;box-shadow:var(--shadow-md)}.json-format-toolbar,.json-format-panel-header,.json-format-actions,.json-format-mode-group,.json-format-stats{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.json-format-status{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border-color);border-radius:999px;background:var(--bg-secondary);color:var(--text-secondary);font-weight:600}.json-format-status-dot{width:10px;height:10px;border-radius:50%;background:var(--text-secondary)}.json-format-status.is-valid{border-color:#22c55e59;color:#16a34a}.json-format-status.is-valid .json-format-status-dot{background:#16a34a}.json-format-status.is-error{border-color:#ef444459;color:#dc2626}.json-format-status.is-error .json-format-status-dot{background:#dc2626}.json-format-note{margin-top:16px;margin-bottom:20px;color:var(--text-secondary);font-size:.95rem}.json-format-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.json-format-panel,.json-format-error,.json-format-copy-message{border:1px solid var(--border-color);border-radius:16px;background:var(--bg-secondary)}.json-format-panel{padding:20px}.json-format-panel-header h3,.json-format-error-header h3{margin:0 0 6px;color:var(--text-primary)}.json-format-panel-header p,.json-format-error-header p,.json-format-error-snippet-label{margin:0;color:var(--text-secondary);font-size:.92rem}.json-format-textarea{width:100%;min-height:360px;margin-top:16px;padding:16px;border:1px solid var(--border-color);border-radius:14px;background:var(--bg-primary);color:var(--text-primary);font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.95rem;line-height:1.55;resize:vertical}.json-format-textarea.output{background:color-mix(in srgb,var(--bg-primary) 90%,white 10%)}.json-format-btn{padding:10px 16px;border-radius:10px;border:1px solid transparent;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease}.json-format-btn.primary{background:var(--accent-color);color:#fff}.json-format-btn.primary:hover{background:var(--accent-hover)}.json-format-btn.secondary{background:transparent;color:var(--text-secondary);border-color:var(--border-color)}.json-format-btn.secondary:hover{border-color:var(--accent-color);color:var(--accent-color)}.json-format-stats{margin-top:16px}.json-format-stat{min-width:110px;padding:12px 14px;border-radius:12px;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-secondary)}.json-format-stat strong{display:block;margin-top:4px;color:var(--text-primary);font-size:1.1rem}.json-format-empty{margin-top:16px;padding:16px;border-radius:12px;background:var(--bg-primary);border:1px dashed var(--border-color);color:var(--text-secondary)}.json-format-error{margin-top:20px;padding:20px}.json-format-error-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}.json-format-error-message{margin-top:14px;font-weight:700;color:#dc2626}.json-format-error-snippet-label{margin-top:14px;margin-bottom:8px}.json-format-error-snippet{margin:0;padding:14px;border-radius:12px;background:#111827;color:#f9fafb;overflow-x:auto;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.88rem;line-height:1.6}.json-format-copy-message{margin-top:14px;padding:14px 16px;color:#b45309}@media (max-width: 900px){.json-format-grid{grid-template-columns:1fr}.json-format-textarea{min-height:280px}}@media (max-width: 640px){.json-format-shell{padding:20px}.json-format-btn,.json-format-actions,.json-format-mode-group{width:100%}.json-format-stat{flex:1 1 calc(33.333% - 8px)}}.data-merge-tool{max-width:960px;margin:0 auto;padding:20px}.data-merge-tool .tool-header{text-align:center;margin-bottom:30px}.data-merge-tool .tool-header h2{font-size:2rem;color:var(--text-primary);margin-bottom:10px}.data-merge-tool .subtitle{color:var(--text-secondary);font-size:1rem}.data-merge-content{background:var(--bg-primary);border-radius:12px;padding:30px;box-shadow:var(--shadow-md)}.merge-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.merge-card{border:2px dashed var(--border-color);border-radius:16px;padding:24px;min-height:220px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;transition:all .25s ease}.merge-card.has-file{border-style:solid}.merge-card.is-dragging,.merge-card:hover{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.merge-card-inner{width:100%;text-align:center}.merge-card-label{font-weight:600;color:var(--text-primary);margin-bottom:16px;font-size:1rem}.merge-drop-icon{font-size:2.5rem;margin-bottom:12px}.merge-drop-title{color:var(--text-primary);font-size:1rem;margin-bottom:18px}.merge-file-info{display:flex;flex-direction:column;align-items:center;gap:12px}.merge-preview{width:100%;margin-top:16px;padding:12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-primary);text-align:left}.merge-preview-title{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.merge-preview-scroll{max-height:180px;overflow:auto}.merge-preview-table{width:100%;border-collapse:collapse;font-size:.85rem}.merge-preview-table th,.merge-preview-table td{padding:6px 8px;border-bottom:1px solid var(--border-color);color:var(--text-primary);text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.merge-preview-table th{color:var(--text-secondary);font-weight:600;background:#00000005}.merge-preview-index{color:var(--text-secondary);font-size:.8rem}.merge-preview-note{margin-top:8px;color:var(--text-secondary);font-size:.8rem}.merge-file-name{color:var(--text-primary);font-weight:600;word-break:break-all}.merge-file-meta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;color:var(--text-secondary);font-size:.9rem}.merge-btn{padding:10px 22px;border-radius:10px;border:none;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:600}.merge-btn.primary{background:var(--accent-color);color:#fff}.merge-btn.primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2196f340}.merge-btn.secondary{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary)}.merge-btn.secondary:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.merge-btn.ghost{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.merge-btn.ghost:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.merge-btn:disabled{opacity:.6;cursor:not-allowed}.merge-hints{margin-top:20px;color:var(--text-secondary);font-size:.9rem;display:flex;flex-direction:column;gap:4px}.merge-actions{margin-top:20px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.merge-add{margin-top:16px;display:flex;justify-content:flex-end}.merge-add .merge-btn{padding:8px 18px}.merge-result{margin-top:24px;background:#4caf501f;border:1px solid rgba(76,175,80,.35);border-radius:12px;padding:16px 20px;color:var(--text-primary)}.merge-result-title{font-weight:700;margin-bottom:12px}.merge-result-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.merge-result-grid span{display:block;color:var(--text-secondary);font-size:.85rem}.merge-result-grid strong{font-size:1rem}.merge-result-note{margin-top:12px;color:var(--text-secondary);font-size:.85rem}.merge-result .merge-preview{margin-top:16px}.merge-error{margin-top:20px;background:#f443361f;border:1px solid rgba(244,67,54,.3);color:#f44336;padding:12px 16px;border-radius:10px;display:flex;gap:8px;align-items:center}.merge-error-icon{font-size:1.1rem}@media (max-width: 768px){.merge-grid{grid-template-columns:1fr}.merge-card{min-height:200px}}.data-dedup-tool{max-width:960px;margin:0 auto;padding:20px}.data-dedup-tool .tool-header{text-align:center;margin-bottom:30px}.data-dedup-tool .tool-header h2{font-size:2rem;color:var(--text-primary);margin-bottom:10px}.data-dedup-tool .subtitle{color:var(--text-secondary);font-size:1rem}.dedup-content{background:var(--bg-primary);border-radius:12px;padding:30px;box-shadow:var(--shadow-md)}.dedup-upload{border:2px dashed var(--border-color);border-radius:16px;padding:70px 40px;text-align:center;cursor:pointer;transition:all .25s ease;background:var(--bg-secondary)}.dedup-upload.is-dragging,.dedup-upload:hover{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.dedup-upload-icon{font-size:2.8rem;margin-bottom:16px}.dedup-upload-title{font-size:1.1rem;color:var(--text-primary);margin-bottom:8px}.dedup-upload-sub{color:var(--text-secondary);font-size:.9rem;margin-bottom:18px}.dedup-btn{padding:10px 22px;border-radius:10px;border:none;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:600}.dedup-btn.primary{background:var(--accent-color);color:#fff}.dedup-btn.primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2196f340}.dedup-btn.secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.dedup-btn.secondary:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.dedup-btn.ghost{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.dedup-btn.ghost:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.dedup-btn:disabled{opacity:.6;cursor:not-allowed}.dedup-file-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;border-radius:12px;background:var(--bg-secondary);border:1px solid var(--border-color);margin-bottom:20px;flex-wrap:wrap}.dedup-file-name{font-weight:600;color:var(--text-primary)}.dedup-file-meta{display:flex;gap:12px;flex-wrap:wrap;color:var(--text-secondary);font-size:.9rem;margin-top:6px}.dedup-columns{border:1px solid var(--border-color);border-radius:12px;padding:18px;margin-bottom:20px;background:var(--bg-secondary)}.dedup-columns-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}.dedup-columns-header h3{margin:0 0 6px;color:var(--text-primary);font-size:1rem}.dedup-columns-header p{margin:0;color:var(--text-secondary);font-size:.9rem}.dedup-columns-actions{display:flex;gap:8px}.dedup-columns-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.dedup-col-option{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;border:1px solid transparent;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.dedup-col-option input{width:16px;height:16px}.dedup-preview{width:100%;margin-top:16px;padding:12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-secondary)}.dedup-preview-title{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.dedup-preview-scroll{max-height:200px;overflow:auto}.dedup-preview-table{width:100%;border-collapse:collapse;font-size:.85rem}.dedup-preview-table th,.dedup-preview-table td{padding:6px 8px;border-bottom:1px solid var(--border-color);color:var(--text-primary);text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.dedup-preview-table th{color:var(--text-secondary);font-weight:600;background:#00000005}.dedup-preview-index{color:var(--text-secondary);font-size:.8rem}.dedup-preview-note{margin-top:8px;color:var(--text-secondary);font-size:.8rem}.dedup-actions{margin-top:20px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.dedup-result{margin-top:24px;padding:16px 20px;border-radius:12px;border:1px solid rgba(76,175,80,.35);background:#4caf501f}.dedup-result-title{font-weight:700;margin-bottom:12px;color:var(--text-primary)}.dedup-result-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.dedup-result-grid span{display:block;color:var(--text-secondary);font-size:.85rem}.dedup-result-grid strong{font-size:1rem}.dedup-error{margin-top:20px;background:#f443361f;border:1px solid rgba(244,67,54,.3);color:#f44336;padding:12px 16px;border-radius:10px;display:flex;gap:8px;align-items:center}.dedup-error-icon{font-size:1.1rem}@media (max-width: 768px){.dedup-file-card{flex-direction:column;align-items:flex-start}}.data-split-tool{max-width:1100px;margin:0 auto;padding:20px}.data-split-tool .tool-header{text-align:center;margin-bottom:28px}.data-split-tool .tool-header h2{font-size:2rem;color:var(--text-primary);margin-bottom:10px}.data-split-tool .subtitle{color:var(--text-secondary);font-size:1rem}.split-content{background:var(--bg-primary);border-radius:16px;padding:28px;box-shadow:var(--shadow-md)}.split-upload,.split-file-card,.split-settings,.split-result,.split-part-card{border:1px solid var(--border-color);border-radius:14px;background:var(--bg-secondary)}.split-upload{padding:36px 24px;text-align:center;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.split-upload.is-dragging{border-color:var(--accent-color);transform:translateY(-2px)}.split-upload-icon{font-size:2.2rem;margin-bottom:10px}.split-upload-title{color:var(--text-primary);font-size:1.1rem;font-weight:700}.split-upload-sub{color:var(--text-secondary);margin-top:8px;margin-bottom:18px}.split-file-card,.split-settings,.split-part-head,.split-download-bar,.split-actions{display:flex;gap:16px;justify-content:space-between;align-items:center}.split-file-card,.split-settings{padding:18px 20px;margin-bottom:20px}.split-file-name{color:var(--text-primary);font-size:1rem;font-weight:700;margin-bottom:8px}.split-file-meta,.split-part-meta{display:flex;gap:12px;flex-wrap:wrap;color:var(--text-secondary);font-size:.9rem}.split-settings h3,.split-part-head h4{margin:0 0 6px;color:var(--text-primary)}.split-settings p{margin:0;color:var(--text-secondary);font-size:.92rem}.split-field{display:flex;flex-direction:column;gap:8px;min-width:180px;color:var(--text-secondary);font-size:.9rem}.split-field input{padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem}.split-actions{margin-top:20px;justify-content:center;flex-wrap:wrap}.split-btn{padding:10px 18px;border-radius:10px;border:1px solid transparent;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease}.split-btn.primary{background:var(--accent-color);color:#fff}.split-btn.primary:hover:not(:disabled){background:var(--accent-hover)}.split-btn.secondary,.split-btn.ghost{background:transparent;color:var(--text-secondary);border-color:var(--border-color)}.split-btn.secondary:hover:not(:disabled),.split-btn.ghost:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.split-btn:disabled{opacity:.6;cursor:not-allowed}.split-preview{margin-top:20px}.split-preview-title{color:var(--text-primary);font-weight:700;margin-bottom:10px}.split-preview-scroll{overflow-x:auto}.split-preview-table{width:100%;border-collapse:collapse;min-width:520px}.split-preview-table th,.split-preview-table td{border:1px solid var(--border-color);padding:10px 12px;text-align:left;color:var(--text-primary);background:var(--bg-primary)}.split-preview-table th{font-size:.9rem}.split-preview-index{color:var(--text-secondary);width:56px}.split-preview-note,.split-download-hint{margin-top:10px;color:var(--text-secondary);font-size:.88rem}.split-result{margin-top:24px;padding:20px}.split-result-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:16px}.split-result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.split-result-grid span{display:block;color:var(--text-secondary);font-size:.88rem;margin-bottom:4px}.split-result-grid strong{color:var(--text-primary);font-size:1rem}.split-download-bar{margin-top:20px;flex-wrap:wrap;align-items:center}.split-parts{display:grid;gap:16px;margin-top:20px}.split-part-card{padding:18px 20px}.split-part-head{flex-wrap:wrap}.split-error{margin-top:20px;background:#f443361f;border:1px solid rgba(244,67,54,.3);color:#f44336;padding:12px 16px;border-radius:10px;display:flex;gap:8px;align-items:center}@media (max-width: 768px){.split-content{padding:20px}.split-file-card,.split-settings,.split-part-head,.split-download-bar{flex-direction:column;align-items:stretch}.split-field{min-width:0;width:100%}.split-preview-table{min-width:420px}}.excel-sheet-merge-tool{max-width:1120px;margin:0 auto;padding:20px}.excel-sheet-merge-tool .tool-header{text-align:center;margin-bottom:28px}.excel-sheet-merge-tool .tool-header h2{margin-bottom:10px;color:var(--text-primary);font-size:2rem}.excel-sheet-merge-tool .subtitle{color:var(--text-secondary);font-size:1rem}.sheet-merge-content{background:var(--bg-primary);border-radius:16px;padding:28px;box-shadow:var(--shadow-md)}.sheet-merge-upload,.sheet-merge-file-card,.sheet-merge-section,.sheet-merge-result,.sheet-merge-sheet-card,.sheet-merge-order-card,.sheet-merge-empty-order{border:1px solid var(--border-color);border-radius:14px;background:var(--bg-secondary)}.sheet-merge-upload{padding:40px 24px;text-align:center;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.sheet-merge-upload.is-dragging{border-color:var(--accent-color);transform:translateY(-2px)}.sheet-merge-upload-icon{font-size:2.3rem;margin-bottom:10px}.sheet-merge-upload-title{color:var(--text-primary);font-size:1.1rem;font-weight:700}.sheet-merge-upload-sub{margin:8px 0 18px;color:var(--text-secondary)}.sheet-merge-file-card,.sheet-merge-section-head,.sheet-merge-order-card,.sheet-merge-actions{display:flex;align-items:center;justify-content:space-between;gap:16px}.sheet-merge-file-card,.sheet-merge-section,.sheet-merge-result{padding:20px}.sheet-merge-file-card{margin-bottom:20px}.sheet-merge-file-name{color:var(--text-primary);font-size:1rem;font-weight:700;margin-bottom:8px}.sheet-merge-file-meta,.sheet-merge-sheet-meta{display:flex;flex-wrap:wrap;gap:12px;color:var(--text-secondary);font-size:.9rem}.sheet-merge-section{margin-bottom:20px}.sheet-merge-section-head{margin-bottom:18px}.sheet-merge-section-head h3,.sheet-merge-result h3{margin:0 0 6px;color:var(--text-primary)}.sheet-merge-section-head p{margin:0;color:var(--text-secondary);font-size:.92rem}.sheet-merge-sheet-list,.sheet-merge-order-list{display:grid;gap:14px}.sheet-merge-sheet-card{padding:16px 18px}.sheet-merge-sheet-card.is-selected{border-color:var(--accent-color);box-shadow:0 0 0 1px #3b82f633}.sheet-merge-sheet-card.is-disabled{opacity:.78}.sheet-merge-sheet-main{display:flex;gap:14px;align-items:flex-start}.sheet-merge-sheet-main input{margin-top:3px}.sheet-merge-sheet-title,.sheet-merge-order-name{color:var(--text-primary);font-size:1rem;font-weight:700;margin-bottom:8px}.sheet-merge-sheet-warning{margin-top:12px;color:#d97706;font-size:.88rem}.sheet-merge-order-card{padding:14px 16px}.sheet-merge-order-card>div:first-child{display:flex;align-items:center;gap:12px}.sheet-merge-order-index{width:32px;height:32px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-secondary);font-size:.9rem;font-weight:700}.sheet-merge-order-actions{display:flex;gap:10px;flex-wrap:wrap}.sheet-merge-empty-order{padding:16px;color:var(--text-secondary);text-align:center}.sheet-merge-actions{margin-top:20px;justify-content:center;flex-wrap:wrap}.sheet-merge-btn{padding:10px 18px;border-radius:10px;border:1px solid transparent;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease}.sheet-merge-btn.primary{background:var(--accent-color);color:#fff}.sheet-merge-btn.primary:hover:not(:disabled){background:var(--accent-hover)}.sheet-merge-btn.secondary,.sheet-merge-btn.ghost{background:transparent;border-color:var(--border-color);color:var(--text-secondary)}.sheet-merge-btn.secondary:hover:not(:disabled),.sheet-merge-btn.ghost:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.sheet-merge-btn:disabled{opacity:.6;cursor:not-allowed}.sheet-merge-error{margin-top:18px;padding:14px 16px;border-radius:12px;background:#ef44441f;color:#ef4444;font-size:.95rem}.sheet-merge-result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:16px}.sheet-merge-result-grid div{padding:14px;border-radius:12px;background:var(--bg-secondary);border:1px solid var(--border-color)}.sheet-merge-result-grid span{display:block;color:var(--text-secondary);font-size:.86rem;margin-bottom:6px}.sheet-merge-result-grid strong{color:var(--text-primary);font-size:.96rem;word-break:break-word}.sheet-merge-preview{margin-top:20px}.sheet-merge-preview-title{color:var(--text-primary);font-weight:700;margin-bottom:10px}.sheet-merge-preview-scroll{overflow-x:auto}.sheet-merge-preview-table{width:100%;min-width:520px;border-collapse:collapse}.sheet-merge-preview-table th,.sheet-merge-preview-table td{border:1px solid var(--border-color);padding:10px 12px;text-align:left;color:var(--text-primary);background:var(--bg-primary)}.sheet-merge-preview-index{color:var(--text-secondary);width:56px}.sheet-merge-preview-note{margin-top:10px;color:var(--text-secondary);font-size:.88rem}@media (max-width: 768px){.sheet-merge-content{padding:20px}.sheet-merge-file-card,.sheet-merge-section-head,.sheet-merge-order-card{flex-direction:column;align-items:flex-start}.sheet-merge-order-actions,.sheet-merge-actions,.sheet-merge-btn{width:100%}}.data-case-tool{max-width:1080px;margin:0 auto;padding:20px}.data-case-tool .tool-header{text-align:center;margin-bottom:28px}.data-case-tool .tool-header h2{font-size:2rem;color:var(--text-primary);margin-bottom:10px}.data-case-tool .subtitle{color:var(--text-secondary);font-size:1rem}.case-content{background:var(--bg-primary);border-radius:16px;padding:28px;box-shadow:var(--shadow-md)}.case-upload,.case-file-card,.case-section,.case-result{border:1px solid var(--border-color);border-radius:14px;background:var(--bg-secondary)}.case-upload{padding:40px 24px;text-align:center;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.case-upload.is-dragging,.case-upload:hover{border-color:var(--accent-color);transform:translateY(-2px)}.case-upload-icon{font-size:2rem;font-weight:800;color:var(--accent-color);margin-bottom:10px}.case-upload-title{color:var(--text-primary);font-size:1.1rem;font-weight:700}.case-upload-sub{color:var(--text-secondary);margin-top:8px;margin-bottom:18px}.case-file-card,.case-section-header,.case-actions{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.case-file-card,.case-section,.case-result{padding:20px;margin-bottom:20px}.case-file-name{color:var(--text-primary);font-size:1rem;font-weight:700;margin-bottom:8px}.case-file-meta{display:flex;gap:12px;flex-wrap:wrap;color:var(--text-secondary);font-size:.9rem}.case-section-header h3,.case-result-title{margin:0 0 6px;color:var(--text-primary)}.case-section-header p,.case-sample-hint{margin:0;color:var(--text-secondary);font-size:.92rem}.case-mode-grid,.case-columns-grid,.case-result-grid{display:grid;gap:12px}.case-mode-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-top:16px}.case-mode-card,.case-col-option{display:flex;align-items:center;gap:10px;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-primary);color:var(--text-primary)}.case-mode-card{padding:14px 16px;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.case-mode-card.is-active{border-color:var(--accent-color);transform:translateY(-1px)}.case-mode-card input,.case-col-option input{width:16px;height:16px;margin:0}.case-columns-actions{display:flex;gap:8px}.case-columns-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-top:16px}.case-col-option{padding:10px 12px;font-size:.92rem}.case-fill-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:16px}.case-fill-card{display:flex;flex-direction:column;gap:8px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-primary);padding:14px}.case-fill-label{color:var(--text-primary);font-size:.92rem;font-weight:700}.case-fill-input{width:100%;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);padding:10px 12px;font-size:.95rem}.case-fill-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4caf501f}.case-btn{padding:10px 18px;border-radius:10px;border:1px solid transparent;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease}.case-btn.primary{background:var(--accent-color);color:#fff}.case-btn.primary:hover:not(:disabled){background:var(--accent-hover)}.case-btn.secondary,.case-btn.ghost{background:transparent;color:var(--text-secondary);border-color:var(--border-color)}.case-btn.secondary:hover:not(:disabled),.case-btn.ghost:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color)}.case-btn:disabled{opacity:.6;cursor:not-allowed}.case-preview,.case-sample{margin-top:20px}.case-preview-title{color:var(--text-primary);font-weight:700;margin-bottom:10px}.case-preview-scroll{overflow-x:auto}.case-preview-table{width:100%;border-collapse:collapse;min-width:560px}.case-preview-table th,.case-preview-table td{border:1px solid var(--border-color);padding:10px 12px;text-align:left;color:var(--text-primary);background:var(--bg-primary);vertical-align:top}.case-preview-table th{font-size:.9rem}.case-preview-index{color:var(--text-secondary);width:56px}.case-preview-note{margin-top:10px;color:var(--text-secondary);font-size:.88rem}.case-actions{margin-top:20px;justify-content:center}.case-actions-result{margin-top:24px}.case-result-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:20px}.case-result-grid span{display:block;color:var(--text-secondary);font-size:.88rem;margin-bottom:4px}.case-result-grid strong{color:var(--text-primary);font-size:1rem}.case-sample-header{margin-bottom:10px}.case-result-title-inline{margin-bottom:4px}.case-rule-list{display:flex;flex-wrap:wrap;gap:10px}.case-rule-pill{display:inline-flex;flex-direction:column;gap:4px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-primary);color:var(--text-primary);padding:10px 12px;min-width:160px}.case-rule-pill span{color:var(--text-secondary);word-break:break-word}.case-error{margin-top:18px;padding:12px 14px;border-radius:10px;background:#f443361f;color:#c62828;border:1px solid rgba(244,67,54,.2)}@media (max-width: 768px){.data-case-tool,.case-content,.case-file-card,.case-section,.case-result{padding:16px}.case-preview-table{min-width:480px}}.data-columns-tool{max-width:1080px;margin:0 auto}.columns-content{display:flex;flex-direction:column;gap:24px}.columns-upload,.columns-file-card,.columns-section,.columns-result,.columns-preview,.columns-error{background:#0f172ac7;border:1px solid rgba(148,163,184,.18);border-radius:20px;box-shadow:0 20px 45px #0f172a38}.columns-upload{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:280px;padding:32px 24px;border-style:dashed;cursor:pointer;text-align:center;transition:transform .18s ease,border-color .18s ease,background .18s ease}.columns-upload.is-dragging{transform:translateY(-2px);border-color:#38bdf8bf;background:#0ea5e924}.columns-upload-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:18px;background:#38bdf824;color:#7dd3fc;font-size:2rem;font-weight:700}.columns-upload-title{color:#f8fafc;font-size:1.2rem;font-weight:700}.columns-upload-sub{color:#cbd5e1}.columns-btn{border:none;border-radius:999px;padding:12px 18px;font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .18s ease,opacity .18s ease,background .18s ease}.columns-btn:hover:not(:disabled){transform:translateY(-1px)}.columns-btn:disabled{cursor:not-allowed;opacity:.65}.columns-btn.primary{background:linear-gradient(135deg,#38bdf8,#0ea5e9);color:#082f49}.columns-btn.secondary{background:#94a3b824;color:#f8fafc}.columns-btn.ghost{background:transparent;color:#bae6fd;border:1px solid rgba(125,211,252,.28)}.columns-file-card,.columns-section,.columns-result,.columns-preview{padding:24px}.columns-file-card{display:flex;align-items:center;justify-content:space-between;gap:16px}.columns-file-name{color:#f8fafc;font-size:1.08rem;font-weight:700;word-break:break-word}.columns-file-meta{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:8px;color:#cbd5e1;font-size:.95rem}.columns-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.columns-section-header h3,.columns-result-title,.columns-preview-title,.columns-output-order-title{margin:0;color:#f8fafc;font-size:1.08rem;font-weight:700}.columns-section-header p{margin:8px 0 0;color:#cbd5e1;line-height:1.6}.columns-actions-inline,.columns-actions{display:flex;flex-wrap:wrap;gap:12px}.columns-list{display:flex;flex-direction:column;gap:12px}.columns-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:16px;border:1px solid rgba(148,163,184,.18);background:#0f172a9e;transition:border-color .18s ease,transform .18s ease,background .18s ease}.columns-card.is-selected{border-color:#7dd3fc57;background:#0ea5e91f}.columns-card.is-muted{opacity:.7}.columns-card.is-drop-target{border-color:#38bdf8e0;transform:translateY(-1px)}.columns-card-main{display:flex;align-items:center;gap:14px;flex:1;min-width:0;cursor:pointer}.columns-card-main input{width:18px;height:18px}.columns-card-copy{display:flex;align-items:center;gap:12px;min-width:0}.columns-card-order{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:#7dd3fc26;color:#7dd3fc;font-size:.9rem;font-weight:700;flex-shrink:0}.columns-card-label{color:#f8fafc;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.columns-card-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.columns-drag-handle{display:inline-flex;align-items:center;justify-content:center;min-width:88px;padding:8px 10px;border-radius:999px;background:#94a3b81f;color:#cbd5e1;font-size:.8rem;font-weight:600}.columns-icon-btn{width:34px;height:34px;border:none;border-radius:10px;background:#94a3b824;color:#f8fafc;cursor:pointer}.columns-icon-btn:disabled{opacity:.4;cursor:not-allowed}.columns-preview-scroll{overflow-x:auto}.columns-preview-table{width:100%;border-collapse:collapse;min-width:520px;margin-top:14px}.columns-preview-table th,.columns-preview-table td{padding:12px 14px;border-bottom:1px solid rgba(148,163,184,.16);text-align:left;color:#e2e8f0}.columns-preview-table th{color:#f8fafc;font-size:.92rem;font-weight:700}.columns-preview-index{color:#7dd3fc;font-weight:700}.columns-preview-note{margin-top:12px;color:#94a3b8;font-size:.9rem}.columns-actions{justify-content:flex-start}.columns-result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:16px}.columns-result-grid div{display:flex;flex-direction:column;gap:6px;padding:16px;border-radius:16px;background:#0f172a8f}.columns-result-grid span{color:#94a3b8;font-size:.9rem}.columns-result-grid strong{color:#f8fafc;font-size:1rem;word-break:break-word}.columns-output-order{margin-top:20px}.columns-output-order-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.columns-output-pill{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#0ea5e924;color:#e0f2fe;font-size:.9rem;font-weight:600}.columns-error{padding:16px 20px;color:#fecaca;background:#7f1d1d7a;border-color:#f8717142}@media (max-width: 768px){.columns-file-card,.columns-section-header,.columns-card{flex-direction:column;align-items:stretch}.columns-card-actions{justify-content:flex-start}.columns-drag-handle{min-width:0}.columns-preview-table{min-width:420px}}.data-email-tool .case-error{margin-top:20px;padding:14px 16px;border:1px solid rgba(220,38,38,.28);border-radius:12px;background:#dc262614;color:#dc2626;font-weight:600}.data-email-tool .email-pill-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.data-email-tool .email-reason-pill{display:inline-flex;align-items:center;border-radius:999px;background:#0f172a14;color:var(--text-primary);padding:8px 12px;font-size:.9rem;font-weight:600}.data-email-tool .case-result-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.data-email-tool .case-result-grid div{display:flex;flex-direction:column;gap:6px;padding:12px 14px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-primary)}.data-email-tool .case-result-grid span{color:var(--text-secondary);font-size:.88rem}.data-email-tool .case-result-grid strong{color:var(--text-primary);font-size:1.05rem}.data-length-tool .case-fill-input[type=number]{-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.data-length-tool .case-fill-input[type=number]::-webkit-outer-spin-button,.data-length-tool .case-fill-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.pdf-merge-tool{max-width:1100px;margin:0 auto;padding:24px 20px 60px}.pdf-merge-tool .tool-header{text-align:center;margin-bottom:18px}.pdf-merge-tool .tool-header h2{margin:0 0 8px;font-size:1.8rem}.pdf-merge-tool .tool-header p{margin:0;color:var(--text-secondary)}.pdf-upload{display:flex;flex-direction:column;align-items:center;gap:12px;margin:18px 0 26px}.pdf-upload input[type=file]{display:none}.pdf-upload-area{border:2px dashed var(--border-color);border-radius:16px;padding:80px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary);width:100%;max-width:920px}.pdf-upload .upload-icon{width:64px;height:64px;margin:0 auto 20px;color:var(--accent-color);display:flex;align-items:center;justify-content:center;font-size:40px}.pdf-session{font-size:.85rem;color:var(--text-secondary)}.pdf-file-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:24px}.pdf-file-card{background:#ffffff08;border:1px solid rgba(148,163,184,.2);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:10px}.pdf-stack{position:relative;height:140px;margin-bottom:8px;width:140px;border:none;background:transparent;padding:0;cursor:pointer}.pdf-stack-img{position:absolute;width:110px;height:140px;object-fit:cover;border-radius:8px;box-shadow:0 6px 14px #0003}.pdf-stack-0{left:0;top:6px;transform:rotate(-2deg)}.pdf-stack-1{left:18px;top:0;transform:rotate(1deg)}.pdf-stack-2{left:36px;top:10px;transform:rotate(-1deg)}.pdf-file-info{margin-bottom:10px}.pdf-file-name{font-weight:700;color:var(--text-primary);font-size:.95rem}.pdf-file-meta{color:var(--text-secondary);font-size:.8rem}.pdf-expand-btn{border:1px solid rgba(59,130,246,.4);background:#3b82f61f;color:#bfdbfe;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.85rem;align-self:flex-start}.pdf-page-preview{display:grid;grid-template-columns:repeat(auto-fit,minmax(98px,1fr));gap:10px;padding:6px 0 2px}.pdf-expanded-area{margin:6px 0 18px;padding:12px 14px 6px;border-radius:14px;border:1px solid rgba(148,163,184,.2);background:#0f172a59}.pdf-expanded-title{color:var(--text-secondary);font-size:.9rem;margin-bottom:8px}.pdf-page-tile{position:relative;background:#0f172a80;border:1px solid rgba(148,163,184,.2);border-radius:12px;padding:5px;display:flex;flex-direction:column;gap:3px;cursor:grab}.pdf-page-tile.selected{border-color:#3b82f699;box-shadow:0 0 0 2px #3b82f633}.pdf-page-check{position:absolute;top:5px;right:5px;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background:#0f172abf;border-radius:6px;border:1px solid rgba(148,163,184,.4);cursor:pointer}.pdf-page-check input{display:none}.pdf-page-check span{width:8px;height:8px;border-radius:3px;border:1px solid rgba(148,163,184,.6)}.pdf-page-check input:checked+span{background:#38bdf8;border-color:#38bdf8;box-shadow:0 0 0 2px #38bdf840}.pdf-page-tile img{width:100%;border-radius:8px;aspect-ratio:3 / 4;object-fit:cover}.pdf-page-meta{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:.68rem;color:var(--text-secondary)}.pdf-page-meta span{color:var(--text-secondary)}.pdf-edit-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:20px 0 16px;padding:12px 14px;border-radius:12px;background:#94a3b814;border:1px solid rgba(148,163,184,.2)}.pdf-edit-tip{color:var(--text-secondary);font-size:.9rem}.pdf-pages-actions button{margin-left:8px;border:1px solid rgba(148,163,184,.3);background:transparent;color:var(--text-secondary);border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.85rem}.pdf-page-delete{border:1px solid rgba(239,68,68,.4);background:#ef44441f;color:#fecaca;border-radius:8px;padding:6px 8px;cursor:pointer;font-size:.8rem}.pdf-empty{color:var(--text-secondary);padding:16px 0;text-align:center}.pdf-merge-btn{width:100%;border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border-radius:12px;padding:12px 16px;font-size:1rem;cursor:pointer}@media (max-width: 720px){.pdf-upload{flex-direction:column;align-items:flex-start}.pdf-upload-area{padding:60px 24px}.pdf-upload-area h3{font-size:18px}.pdf-upload-area p{font-size:14px}.pdf-upload .upload-icon{width:48px;height:48px;font-size:32px}.pdf-edit-toolbar{flex-direction:column;align-items:flex-start}}.pdf-compress-tool{max-width:1100px;margin:0 auto;padding:24px 20px 60px}.pdf-compress-tool .tool-header{text-align:center;margin-bottom:18px}.pdf-compress-tool .tool-header h2{margin:0 0 8px;font-size:1.8rem}.pdf-compress-tool .tool-header p{margin:0;color:var(--text-secondary)}.pdf-compress-upload input[type=file]{display:none}.pdf-upload-area{border:2px dashed var(--border-color);border-radius:16px;padding:80px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary);width:100%;max-width:920px;margin:0 auto}.pdf-upload-area:hover,.pdf-upload-area.dragging{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.pdf-upload-area h3{font-size:22px;font-weight:600;margin:0 0 10px;color:var(--text-primary)}.pdf-upload-area p{font-size:15px;color:var(--text-secondary);margin:0}.pdf-compress-upload .upload-icon{width:64px;height:64px;margin:0 auto 20px;color:var(--accent-color);display:flex;align-items:center;justify-content:center;font-size:40px}.pdf-compress-panel{margin-top:18px;background:#0f172a66;border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:18px}.pdf-file-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:16px;border-bottom:1px solid rgba(148,163,184,.2)}.pdf-file-name{color:var(--text-primary);font-weight:600;margin-bottom:6px}.pdf-file-size{color:var(--text-secondary);font-size:.9rem}.pdf-change-btn{border:1px solid rgba(148,163,184,.4);background:transparent;color:var(--text-secondary);border-radius:8px;padding:6px 12px;cursor:pointer;font-size:.85rem}.pdf-levels{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:18px 0}.pdf-level{border:1px solid rgba(148,163,184,.2);background:#0f172a4d;border-radius:12px;padding:14px;cursor:pointer;color:var(--text-primary);text-align:left;font-weight:600;display:flex;flex-direction:column;gap:6px}.pdf-level span{color:var(--text-secondary);font-size:.85rem;font-weight:400}.pdf-level.active{border-color:#3b82f6cc;box-shadow:0 0 0 2px #3b82f633}.pdf-compress-btn{width:100%;border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border-radius:12px;padding:12px 16px;font-size:1rem;cursor:pointer}.pdf-compress-result{margin-top:16px;display:flex;flex-direction:column;gap:8px;color:var(--text-primary)}.pdf-download-btn{border:none;background:#22c55e33;color:#bbf7d0;border-radius:10px;padding:10px 12px;cursor:pointer}@media (max-width: 720px){.pdf-file-summary{flex-direction:column;align-items:flex-start}.pdf-upload-area{padding:60px 24px}.pdf-upload-area h3{font-size:18px}.pdf-upload-area p{font-size:14px}.pdf-compress-upload .upload-icon{width:48px;height:48px;font-size:32px}}.pdf-to-image-tool{max-width:1120px;margin:0 auto}.pdf-to-image-tool .tool-header{text-align:center;margin-bottom:24px}.pdf-to-image-tool .tool-header h2{margin-bottom:8px}.pdf-to-image-tool .tool-header p{color:var(--text-secondary, #6b7280)}.pdf-to-image-upload input[type=file]{display:none}.pdf-to-image-panel{margin-top:24px;display:grid;gap:20px}.pdf-to-image-summary{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:20px;background:#ffffffd1;border:1px solid rgba(15,23,42,.08);border-radius:18px}.pdf-export-toolbar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;align-items:center}.pdf-format-toggle{display:inline-flex;gap:10px}.pdf-format-btn,.pdf-change-btn,.pdf-download-all-btn,.pdf-page-download-btn{border:none;border-radius:999px;cursor:pointer;font-weight:700;transition:transform .18s ease,opacity .18s ease,background .18s ease}.pdf-format-btn,.pdf-change-btn{padding:10px 16px;background:#e5e7eb;color:#111827}.pdf-format-btn.active{background:#0f172a;color:#fff}.pdf-download-all-btn,.pdf-page-download-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.pdf-download-all-btn{padding:12px 18px}.pdf-page-download-btn{padding:10px 14px}.pdf-to-image-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.pdf-image-card{background:#ffffffe6;border:1px solid rgba(15,23,42,.08);border-radius:20px;overflow:hidden;box-shadow:0 16px 40px #0f172a14}.pdf-image-card img{display:block;width:100%;aspect-ratio:3 / 4;object-fit:cover;background:#e5e7eb}.pdf-image-card-body{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:14px}.pdf-image-page-title{font-weight:700;margin-bottom:4px}.pdf-image-page-meta{color:var(--text-secondary, #6b7280);font-size:.92rem}.pdf-format-btn:hover,.pdf-change-btn:hover,.pdf-download-all-btn:hover,.pdf-page-download-btn:hover{transform:translateY(-1px)}.pdf-format-btn:disabled,.pdf-change-btn:disabled,.pdf-download-all-btn:disabled,.pdf-page-download-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 720px){.pdf-to-image-summary,.pdf-image-card-body,.pdf-export-toolbar{flex-direction:column;align-items:stretch}.pdf-page-download-btn,.pdf-download-all-btn{width:100%}}.pdf-extract-tool{display:flex;flex-direction:column;gap:24px}.pdf-extract-upload input{display:none}.pdf-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:220px;padding:28px;border:2px dashed rgba(56,189,248,.38);border-radius:24px;background:#0f172a61;cursor:pointer;text-align:center;transition:border-color .16s ease,background .16s ease,transform .16s ease}.pdf-upload-area.dragging,.pdf-upload-area:hover{border-color:#38bdf8e0;background:#082f4961;transform:translateY(-1px)}.pdf-extract-panel{display:flex;flex-direction:column;gap:20px;padding:24px;border:1px solid rgba(148,163,184,.22);border-radius:24px;background:#0f172a80;box-shadow:0 18px 40px #0f172a29}.pdf-extract-summary{display:flex;align-items:center;justify-content:space-between;gap:16px}.pdf-file-name{font-size:1.1rem;font-weight:700}.pdf-file-meta{color:#e2e8f0bf;margin-top:4px}.pdf-change-btn{padding:10px 14px;border:1px solid rgba(148,163,184,.28);border-radius:999px;background:#0f172a85;color:inherit;cursor:pointer}.pdf-extract-controls{display:flex;flex-direction:column;gap:12px}.pdf-extract-field{display:flex;flex-direction:column;gap:8px;font-weight:600}.pdf-extract-field input{width:100%;padding:12px 14px;border:1px solid rgba(148,163,184,.28);border-radius:14px;background:#0f172ac7;color:inherit;font-size:1rem}.pdf-extract-field input:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf82e}.pdf-extract-presets{display:flex;flex-wrap:wrap;gap:10px}.pdf-extract-presets button,.pdf-extract-submit{border:none;border-radius:999px;cursor:pointer;transition:transform .16s ease,opacity .16s ease,background .16s ease}.pdf-extract-presets button{padding:10px 14px;background:#94a3b824;color:inherit}.pdf-extract-presets button:hover,.pdf-extract-submit:hover:not(:disabled){transform:translateY(-1px)}.pdf-extract-hint,.pdf-extract-selection{color:#e2e8f0d1;font-size:.95rem}.pdf-extract-error{padding:12px 14px;border:1px solid rgba(248,113,113,.32);border-radius:14px;background:#7f1d1d3d;color:#fecaca}.pdf-extract-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}.pdf-extract-page{display:flex;flex-direction:column;gap:10px;padding:12px;border:1px solid rgba(148,163,184,.22);border-radius:18px;background:#0f172a70;color:inherit;cursor:pointer;text-align:left;transition:transform .16s ease,border-color .16s ease,background .16s ease}.pdf-extract-page:hover{transform:translateY(-2px);border-color:#38bdf880}.pdf-extract-page.selected{border-color:#38bdf8e6;background:#082f498c;box-shadow:0 0 0 2px #38bdf81f}.pdf-extract-page img{width:100%;aspect-ratio:3 / 4;object-fit:cover;border-radius:12px;background:#ffffff14}.pdf-extract-page span{font-weight:600}.pdf-extract-footer{display:flex;align-items:center;justify-content:space-between;gap:16px}.pdf-extract-preview-copy{color:#e2e8f0d1}.pdf-extract-submit{padding:12px 20px;background:linear-gradient(135deg,#0ea5e9,#2563eb);color:#eff6ff;font-weight:700}.pdf-extract-submit:disabled{cursor:not-allowed;opacity:.55}@media (max-width: 720px){.pdf-extract-panel,.pdf-extract-summary,.pdf-extract-footer{flex-direction:column;align-items:stretch}.pdf-extract-submit{width:100%}}.pdf-split-every-tool{max-width:1120px;margin:0 auto}.pdf-split-every-tool .tool-header{text-align:center;margin-bottom:24px}.pdf-split-every-tool .tool-header h2{margin-bottom:8px}.pdf-split-every-tool .tool-header p,.pdf-split-preview-copy,.pdf-split-footer-copy,.pdf-split-preview-meta{color:var(--text-secondary, #6b7280)}.pdf-split-upload input[type=file]{display:none}.pdf-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:220px;padding:28px;border:2px dashed rgba(37,99,235,.28);border-radius:24px;background:#ffffffd1;cursor:pointer;text-align:center;transition:border-color .18s ease,background .18s ease,transform .18s ease}.pdf-upload-area.dragging,.pdf-upload-area:hover{border-color:#2563ebb8;background:#dbeafed1;transform:translateY(-1px)}.upload-icon{font-size:2rem}.pdf-split-panel{margin-top:24px;display:grid;gap:20px}.pdf-split-summary,.pdf-split-controls,.pdf-split-footer{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:20px;background:#ffffffe6;border:1px solid rgba(15,23,42,.08);border-radius:18px}.pdf-file-meta{margin-top:4px;color:var(--text-secondary, #6b7280)}.pdf-change-btn,.pdf-split-submit,.pdf-split-presets button{border:none;border-radius:999px;cursor:pointer;font-weight:700;transition:transform .18s ease,opacity .18s ease,background .18s ease}.pdf-split-controls{flex-direction:column;align-items:stretch}.pdf-split-field{display:grid;gap:8px;font-weight:700}.pdf-split-field input{width:100%;padding:12px 14px;border:1px solid rgba(15,23,42,.12);border-radius:14px;background:#fff;color:#111827;font-size:1rem}.pdf-split-field input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.pdf-split-presets{display:flex;flex-wrap:wrap;gap:10px}.pdf-split-presets button{padding:10px 14px;background:#e0e7ff;color:#1e3a8a}.pdf-split-error{padding:12px 14px;border-radius:14px;border:1px solid rgba(239,68,68,.24);background:#fef2f2f2;color:#b91c1c}.pdf-split-preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px}.pdf-split-preview-card{display:grid;gap:8px;padding:18px;background:#ffffffeb;border:1px solid rgba(15,23,42,.08);border-radius:18px;box-shadow:0 16px 40px #0f172a14}.pdf-split-preview-index{font-size:.9rem;font-weight:700;color:#2563eb}.pdf-split-preview-range{font-size:1.05rem;font-weight:700;color:#111827}.pdf-split-submit{padding:12px 18px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.pdf-change-btn:hover,.pdf-split-submit:hover,.pdf-split-presets button:hover{transform:translateY(-1px)}.pdf-change-btn:disabled,.pdf-split-submit:disabled,.pdf-split-presets button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 720px){.pdf-split-summary,.pdf-split-footer{flex-direction:column;align-items:stretch}.pdf-split-submit{width:100%}}.image-to-pdf-tool{display:flex;flex-direction:column;gap:24px}.image-to-pdf-upload input{display:none}.image-to-pdf-dropzone{border:2px dashed var(--border-color, #cbd5e1);border-radius:20px;padding:32px 20px;text-align:center;background:var(--card-bg, #ffffff);cursor:pointer;transition:border-color .2s ease,transform .2s ease}.image-to-pdf-dropzone.dragging{border-color:#2563eb;transform:translateY(-2px)}.image-to-pdf-toolbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-end;flex-wrap:wrap}.image-to-pdf-stats{display:flex;gap:16px;flex-wrap:wrap;color:var(--text-secondary, #475569)}.image-to-pdf-controls{display:flex;gap:12px;flex-wrap:wrap}.image-to-pdf-controls label{display:flex;flex-direction:column;gap:6px;color:var(--text-secondary, #475569);font-size:14px}.image-to-pdf-controls select{min-width:140px;padding:10px 12px;border-radius:10px;border:1px solid var(--border-color, #cbd5e1);background:var(--card-bg, #ffffff);color:inherit}.image-to-pdf-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.image-to-pdf-card{background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #e2e8f0);border-radius:16px;overflow:hidden;box-shadow:0 12px 30px #0f172a14}.image-to-pdf-card.dragging{opacity:.6}.image-to-pdf-card img{width:100%;aspect-ratio:4 / 3;object-fit:cover;background:#f8fafc}.image-to-pdf-card-body{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:14px}.image-to-pdf-card-title{font-weight:700;margin-bottom:4px}.image-to-pdf-card-meta{color:var(--text-secondary, #64748b);font-size:13px;word-break:break-word}.image-to-pdf-remove,.image-to-pdf-submit{border:none;border-radius:12px;cursor:pointer}.image-to-pdf-remove{padding:10px 12px;background:#e2e8f0;color:#0f172a}.image-to-pdf-empty{padding:24px;border-radius:16px;background:#94a3b81f;color:var(--text-secondary, #475569);text-align:center}.image-to-pdf-submit{align-self:flex-start;padding:14px 22px;background:linear-gradient(135deg,#0f766e,#0ea5e9);color:#fff;font-weight:700}.image-to-pdf-submit:disabled,.image-to-pdf-remove:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 720px){.image-to-pdf-grid{grid-template-columns:1fr}.image-to-pdf-submit{width:100%}}.pdf-grayscale-tool{max-width:1120px;margin:0 auto}.pdf-grayscale-tool .tool-header{text-align:center;margin-bottom:24px}.pdf-grayscale-tool .tool-header h2{margin-bottom:8px}.pdf-grayscale-tool .tool-header p,.pdf-grayscale-preview-copy span{color:var(--text-secondary, #6b7280)}.pdf-grayscale-upload input[type=file]{display:none}.pdf-grayscale-panel{margin-top:24px;display:grid;gap:20px}.pdf-grayscale-summary{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:20px;background:#ffffffd1;border:1px solid rgba(15,23,42,.08);border-radius:18px}.pdf-grayscale-preview-copy{display:grid;gap:6px;padding:18px 20px;border-radius:18px;background:#ffffffe6;border:1px solid rgba(15,23,42,.08)}.pdf-file-name{font-size:1.05rem;font-weight:700}.pdf-file-meta,.pdf-image-page-meta{margin-top:4px;color:var(--text-secondary, #6b7280)}.pdf-image-page-title{font-weight:700}.pdf-change-btn,.pdf-download-all-btn{border:none;border-radius:999px;cursor:pointer;font-weight:700;transition:transform .18s ease,opacity .18s ease,background .18s ease}.pdf-change-btn{padding:10px 16px;background:#e5e7eb;color:#111827}.pdf-download-all-btn{padding:12px 18px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.pdf-grayscale-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}.pdf-grayscale-card{background:#ffffffe6;border:1px solid rgba(15,23,42,.08);border-radius:20px;overflow:hidden;box-shadow:0 16px 40px #0f172a14}.pdf-grayscale-card img{display:block;width:100%;aspect-ratio:3 / 4;object-fit:cover;background:#e5e7eb}.pdf-grayscale-card img.is-grayscale{filter:grayscale(100%)}.pdf-grayscale-card-body{padding:14px}.pdf-grayscale-actions{display:flex;justify-content:center}.pdf-change-btn:hover,.pdf-download-all-btn:hover{transform:translateY(-1px)}.pdf-change-btn:disabled,.pdf-download-all-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 720px){.pdf-grayscale-summary{flex-direction:column;align-items:stretch}.pdf-grayscale-actions .pdf-download-all-btn{width:100%}}.pdf-page-resize-tool{display:flex;flex-direction:column;gap:24px}.pdf-page-resize-tool .tool-header p,.pdf-page-resize-copy span,.pdf-page-resize-preview-copy span,.pdf-page-resize-footer-copy,.pdf-page-resize-option span,.pdf-page-resize-preview-meta,.pdf-size-tag{color:var(--text-secondary, #5f6b7a)}.pdf-page-resize-upload input[type=file]{display:none}.pdf-page-resize-panel,.pdf-page-resize-summary,.pdf-page-resize-insights,.pdf-page-resize-controls,.pdf-page-resize-preview-copy,.pdf-page-resize-footer{background:var(--card-bg, #fff);border:1px solid var(--border-color, #d8dee9);border-radius:18px;box-shadow:0 12px 30px #0f172a0f}.pdf-page-resize-panel{display:flex;flex-direction:column;gap:20px;padding:20px}.pdf-page-resize-summary,.pdf-page-resize-insights,.pdf-page-resize-preview-copy,.pdf-page-resize-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px}.pdf-page-resize-copy,.pdf-page-resize-preview-copy{display:flex;flex-direction:column;gap:6px}.pdf-page-resize-tags{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.pdf-size-tag{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#0f172a0f;font-size:.9rem;white-space:nowrap}.pdf-page-resize-controls{display:grid;gap:18px;padding:20px}.pdf-page-resize-group{display:flex;flex-direction:column;gap:12px}.pdf-page-resize-group-title,.pdf-page-resize-preview-title{font-weight:700;color:var(--text-primary, #111827)}.pdf-page-resize-option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.pdf-page-resize-option{display:flex;flex-direction:column;gap:6px;align-items:flex-start;text-align:left;padding:14px 16px;border-radius:14px;border:1px solid var(--border-color, #d8dee9);background:#ffffffeb;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.pdf-page-resize-option:hover{transform:translateY(-1px);border-color:#0f766e}.pdf-page-resize-option.active{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f;background:#0f766e14}.pdf-page-resize-preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.pdf-page-resize-preview-card{display:flex;flex-direction:column;gap:12px;padding:18px;border-radius:18px;border:1px solid var(--border-color, #d8dee9);background:linear-gradient(180deg,#f8fafcfa,#f1f5f9f2)}.pdf-page-preview-frame{position:relative;width:100%;overflow:hidden;border-radius:14px;border:1px solid rgba(15,23,42,.12);background:linear-gradient(180deg,#fffffffa,#f1f5f9fa),repeating-linear-gradient(45deg,#94a3b814,#94a3b814 10px,#ffffff0d 10px,#ffffff0d 20px)}.pdf-page-preview-frame img{width:100%;height:100%;display:block;object-position:center}.pdf-page-preview-frame.original img,.pdf-page-preview-frame.is-contain img{object-fit:contain}.pdf-page-preview-frame.is-cover img{object-fit:cover}.pdf-page-resize-submit,.pdf-change-btn{border:none;cursor:pointer}.pdf-page-resize-submit{padding:12px 20px;border-radius:999px;background:#0f766e;color:#fff;font-weight:700}.pdf-page-resize-submit:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 900px){.pdf-page-resize-summary,.pdf-page-resize-insights,.pdf-page-resize-preview-copy,.pdf-page-resize-footer{flex-direction:column;align-items:flex-start}.pdf-page-resize-tags{justify-content:flex-start}.pdf-page-resize-option-grid,.pdf-page-resize-preview-grid{grid-template-columns:1fr}.pdf-page-resize-submit{width:100%}}.media-editor-tool{max-width:1400px;margin:0 auto;padding:24px 20px 60px}.media-editor-tool .tool-header{text-align:center;margin-bottom:18px}.media-editor-tool .tool-header h2{margin:0 0 8px;font-size:1.8rem}.media-editor-tool .tool-header p{margin:0;color:var(--text-secondary)}.media-upload input[type=file]{display:none}.media-upload-area{border:2px dashed rgba(148,163,184,.4);border-radius:14px;padding:26px 18px;text-align:center;cursor:pointer;transition:all .3s ease;background:#0f172a59;width:100%}.media-upload-area:hover,.media-upload-area.dragging{border-color:var(--accent-color);background:#2196f30d;transform:translateY(-2px)}.media-upload-area h3{font-size:16px;font-weight:600;margin:0 0 6px;color:var(--text-primary)}.media-upload-area p{font-size:12px;color:var(--text-secondary);margin:0}.media-upload .upload-icon{width:36px;height:36px;margin:0 auto 12px;color:var(--accent-color);display:flex;align-items:center;justify-content:center;font-size:22px}.media-layout{display:grid;grid-template-columns:280px 1fr;gap:20px}.media-sidebar{display:flex;flex-direction:column;gap:16px}.media-panel{background:#0f172a73;border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:14px}.panel-title{color:var(--text-secondary);font-size:.85rem;letter-spacing:.6px;text-transform:uppercase}.media-settings{display:grid;gap:10px}.media-setting-row{background:#0f172a66;border:1px solid rgba(148,163,184,.2);border-radius:12px;padding:10px 12px;display:flex;flex-direction:column;gap:6px}.media-setting-row label{font-size:.85rem;color:var(--text-secondary)}.media-setting-row select{background:var(--bg-primary);color:var(--text-primary);border:1px solid rgba(148,163,184,.3);border-radius:8px;padding:8px 10px}.auto-cut-settings{gap:10px}.auto-cut-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.auto-cut-field{display:grid;gap:6px;color:var(--text-secondary);font-size:.82rem}.auto-cut-field input{background:var(--bg-primary);color:var(--text-primary);border:1px solid rgba(148,163,184,.3);border-radius:8px;padding:8px 10px}.auto-cut-checkbox{display:flex;align-items:flex-start;gap:8px;color:var(--text-secondary);font-size:.82rem}.auto-cut-checkbox input{margin-top:2px}.auto-cut-btn{border:1px solid rgba(56,189,248,.4);background:#38bdf81f;color:#bae6fd;border-radius:10px;padding:8px 12px;font-size:.9rem;cursor:pointer}.auto-cut-btn:disabled{opacity:.6;cursor:not-allowed}.auto-cut-actions{display:flex;gap:8px}.auto-cut-btn-apply{border-color:#22c55e73;background:#22c55e24;color:#bbf7d0}.auto-cut-status{color:var(--text-secondary);font-size:.78rem}.media-list{display:grid;gap:10px}.media-list.compact{gap:8px}.media-chip{border:1px solid rgba(148,163,184,.2);background:#0f172a66;color:var(--text-primary);border-radius:12px;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;font-size:.8rem;cursor:pointer}.media-chip.active{border-color:#3b82f6b3;box-shadow:0 0 0 2px #3b82f633}.media-empty{color:var(--text-secondary);font-size:.85rem;padding:8px 0}.media-workspace{display:flex;flex-direction:column;gap:18px}.media-preview{background:#0f172a73;border:1px solid rgba(148,163,184,.2);border-radius:18px;padding:16px;min-height:360px;display:flex;flex-direction:column;gap:12px}.preview-header{display:flex;align-items:baseline;gap:12px}.preview-title{font-size:1rem;color:var(--text-primary);font-weight:600}.preview-meta{font-size:.8rem;color:var(--text-secondary)}.preview-screen{flex:0 0 auto;border-radius:14px;background:#000;display:grid;place-items:center;overflow:hidden;align-self:center;width:100%;height:clamp(240px,45vw,420px)}.preview-player{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;background:#000}.preview-audio{display:grid;gap:16px;justify-items:center;color:var(--text-secondary)}.preview-audio-icon{font-size:40px}.preview-empty{color:var(--text-secondary);font-size:.9rem}.media-timeline-panel{background:#0a0d12bf;border:1px solid rgba(148,163,184,.16);border-radius:18px;padding:16px}.timeline-header{position:relative;display:flex;align-items:center;margin-bottom:10px}.timeline-title{font-weight:600;color:var(--text-primary)}.timeline-actions-row{position:relative;flex:1;min-height:34px}.timeline-actions{position:absolute;left:50%;transform:translate(-50%);display:flex;gap:8px}.timeline-actions-right{position:absolute;right:0;display:flex;gap:8px}.timeline-controls{display:flex;justify-content:center;align-items:center;gap:12px}.timeline-current-time{display:flex;align-items:center;justify-self:center;color:var(--text-secondary);font-size:.8rem;letter-spacing:.02em}.timeline-current-time span{border:1px solid rgba(148,163,184,.25);border-radius:999px;padding:2px 10px;background:#0c10188c}.timeline-btn{border:1px solid rgba(148,163,184,.3);background:transparent;color:var(--text-secondary);border-radius:8px;width:34px;height:30px;font-size:.9rem;display:inline-flex;align-items:center;justify-content:center}.timeline-btn.is-active{border-color:#3b82f699;background:#3b82f62e;color:#bfdbfe}.tooltip{position:relative;display:inline-flex;align-items:center}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%,-8px);background:#0f172af2;color:#e2e8f0;font-size:.7rem;padding:4px 8px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:10}.tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%,-2px);border:6px solid transparent;border-top-color:#0f172af2;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:10}.tooltip:hover:after,.tooltip:hover:before,.tooltip:focus-within:after,.tooltip:focus-within:before{opacity:1;transform:translate(-50%,-12px)}.tooltip:focus-within:before{transform:translate(-50%,-6px)}.timeline-icon{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.timeline-track{display:grid;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none}.timeline-zoom{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.8rem}.timeline-zoom button{border:1px solid rgba(148,163,184,.3);background:#0f172a66;color:var(--text-primary);border-radius:8px;padding:4px 10px;cursor:pointer}.timeline-scroll{overflow-x:auto;padding-bottom:6px;cursor:grab;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.45) rgba(15,23,42,.2)}.timeline-scroll.is-panning{cursor:grabbing}.timeline-scroll::-webkit-scrollbar{height:8px}.timeline-scroll::-webkit-scrollbar-track{background:#0f172a33;border-radius:999px}.timeline-scroll::-webkit-scrollbar-thumb{background:#94a3b873;border-radius:999px}.timeline-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#e2e8f0b3;font-size:.85rem;pointer-events:none;text-align:center}.timeline-strip{display:grid;gap:12px;background:linear-gradient(180deg,#121722f2,#0a0d14f2);border:1px solid rgba(148,163,184,.12);border-radius:12px;padding:8px 0 10px;overflow:visible}.timeline-body{overflow:hidden}.timeline-ruler{position:relative;height:18px;color:var(--text-secondary);font-size:.75rem}.timeline-ruler span{position:absolute;top:0;white-space:nowrap}.timeline-body{position:relative;min-height:112px;background:repeating-linear-gradient(90deg,rgba(148,163,184,.06) 0 1px,transparent 1px var(--grid-step, 80px));border:none;border-radius:0;padding:4px 0;display:flex;gap:0;align-items:center;width:100%;min-width:100%;box-sizing:border-box}.timeline-playhead{position:absolute;top:12px;bottom:12px;left:0;width:2px;background:#e2e8f0;box-shadow:0 0 0 4px #e2e8f01f;pointer-events:none;z-index:5}.playhead-handle{position:absolute;top:-7px;left:-7px;width:16px;height:16px;border-radius:50%;background:#e2e8f0;box-shadow:0 0 0 6px #e2e8f033;z-index:6}.timeline-clip{position:relative;background:#0f172abf;border:1px solid rgba(148,163,184,.16);border-radius:0;padding:10px 8px 12px;display:grid;gap:8px;cursor:pointer;flex-shrink:0;z-index:1;box-sizing:border-box}.timeline-clip.active{border-color:#3b82f6b3;box-shadow:0 0 0 2px #3b82f633,0 0 18px #3b82f626}.clip-trim{position:absolute;top:0;bottom:0;width:6px;border:none;padding:0;background:#94a3b866;cursor:ew-resize;z-index:4}.clip-trim-start{left:-3px}.clip-trim-end{right:-3px}.clip-trim-overlay{position:absolute;top:0;bottom:0;background:#02061799;z-index:2;pointer-events:none}.clip-trim-overlay.trim-left{left:0}.clip-trim-overlay.trim-right{right:0}.clip-trim-window{position:absolute;top:0;bottom:0;border:2px solid rgba(59,130,246,.8);box-shadow:0 0 0 1px #3b82f633;z-index:3;pointer-events:none}.clip-auto-cut-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1}.clip-auto-cut-window{position:absolute;top:0;bottom:0;background:#22c55e33;border-left:1px solid rgba(74,222,128,.6);border-right:1px solid rgba(74,222,128,.6)}.clip-auto-cut-marker{position:absolute;top:0;bottom:0;width:2px;transform:translate(-1px);background:#4ade80f2}.clip-auto-cut-drop{position:absolute;top:0;right:0;bottom:0;left:0;background:#f8717124}.clip-label{position:absolute;top:6px;left:8px;font-size:.7rem;color:#e2e8f0;background:#0f172acc;border:1px solid rgba(148,163,184,.2);border-radius:4px;padding:2px 6px;z-index:4}.clip-handle{position:absolute;top:6px;right:8px;border:1px solid rgba(59,130,246,.4);background:#3b82f61f;color:#bfdbfe;border-radius:8px;padding:2px 6px;font-size:.7rem;cursor:grab;opacity:0;transition:opacity .2s ease;z-index:4}.clip-frames{display:flex;gap:2px;align-items:stretch;height:52px;padding:0;border-radius:0;border:1px solid rgba(148,163,184,.18);background:#080b10f2}.clip-frame{flex:1;min-width:16px;border-radius:0;background:linear-gradient(135deg,#3b82f640,#22c55e40);border:1px solid rgba(148,163,184,.12);background-size:cover;background-position:center}.clip-frame.has-thumb{background-color:#0f172a}.clip-times{position:absolute;bottom:6px;left:8px;right:8px;display:flex;justify-content:space-between;color:#e2e8f0cc;font-size:.7rem;pointer-events:none;z-index:4}.clip-remove{position:absolute;bottom:6px;right:8px;border:1px solid rgba(239,68,68,.4);background:#ef44441f;color:#fecaca;border-radius:8px;padding:2px 6px;font-size:.7rem;cursor:pointer;opacity:0;transition:opacity .2s ease;z-index:4}.timeline-clip:hover .clip-handle,.timeline-clip:hover .clip-remove{opacity:1}.media-export{border:none;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border-radius:12px;padding:12px 18px;font-size:1rem;cursor:pointer}.media-progress-wrap{display:grid;gap:6px}.media-progress-bar{width:100%;height:8px;border-radius:999px;background:#94a3b833;overflow:hidden}.media-progress-fill{height:100%;background:linear-gradient(90deg,#38bdf8,#22c55e);transition:width .15s ease}.media-progress{color:var(--text-secondary);font-size:.9rem}@media (max-width: 720px){.media-layout{grid-template-columns:1fr}.media-upload-area{padding:24px 16px}.auto-cut-grid{grid-template-columns:1fr}.auto-cut-actions{flex-direction:column}.timeline-header{align-items:flex-start;flex-direction:column;gap:10px}.timeline-actions-row{width:100%;min-height:0;display:flex;align-items:center;gap:8px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.timeline-actions-row::-webkit-scrollbar{height:6px}.timeline-actions-row::-webkit-scrollbar-track{background:#0f172a33;border-radius:999px}.timeline-actions-row::-webkit-scrollbar-thumb{background:#94a3b866;border-radius:999px}.timeline-actions,.timeline-actions-right{position:static;transform:none;flex-wrap:nowrap}.timeline-actions{justify-content:flex-start;gap:6px}.timeline-actions-right{margin-left:auto;gap:6px}.timeline-zoom{gap:6px}.timeline-track{touch-action:pan-y}.timeline-scroll{scroll-snap-type:none;-webkit-overflow-scrolling:touch}.timeline-strip{touch-action:pan-y}}.lottery-tool{max-width:1100px;margin:0 auto;padding:24px}.tool-header{text-align:center;margin-bottom:30px}.tool-header h2{font-size:2rem;color:var(--text-primary);margin-bottom:10px}.subtitle{color:var(--text-secondary);font-size:1rem}.lottery-layout{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.9fr);gap:24px}.lottery-card{background:var(--bg-primary);border-radius:16px;padding:24px;box-shadow:var(--shadow-md);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:18px}.lottery-card-title{margin:0;font-size:1.25rem;color:var(--text-primary)}.lottery-field{display:flex;flex-direction:column;gap:8px}.lottery-field label{font-weight:600;color:var(--text-primary)}.lottery-input,.lottery-textarea{width:100%;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:10px;padding:12px 14px;font-size:1rem}.prize-list{display:flex;flex-direction:column;gap:10px}.prize-header{display:grid;grid-template-columns:minmax(0,1fr) 90px auto;gap:10px;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase}.prize-row{display:grid;grid-template-columns:minmax(0,1fr) 90px auto;gap:10px;align-items:center}.prize-input{min-width:0}.prize-count{text-align:center}.prize-remove{white-space:nowrap}.prize-add{align-self:flex-start}.lottery-textarea{min-height:180px;resize:vertical}.lottery-helper{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--text-secondary);font-size:.9rem}.lottery-counts{display:flex;gap:12px;flex-wrap:wrap}.lottery-actions{display:flex;gap:10px}.lottery-btn{border:none;border-radius:10px;padding:10px 16px;font-size:.95rem;cursor:pointer;font-weight:600;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.lottery-btn.primary{background:var(--accent-color);color:#fff}.lottery-btn.primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 16px #2196f34d}.lottery-btn.secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.lottery-btn.secondary:hover:not(:disabled){background:var(--border-color)}.lottery-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.lottery-file-input{display:none}.lottery-error{color:#ff5252;background:#ff52521f;border:1px solid rgba(255,82,82,.3);border-radius:10px;padding:10px 12px;font-size:.95rem}.lottery-draw-box{background:linear-gradient(135deg,#2196f326,#2196f30d);border:1px solid rgba(66,165,245,.4);border-radius:16px;padding:24px;text-align:center;min-height:190px;display:flex;flex-direction:column;justify-content:center;gap:10px}.draw-topic{font-size:1rem;color:var(--text-secondary)}.draw-prize{font-size:1.05rem;color:var(--text-primary);font-weight:600}.draw-name{font-size:2rem;font-weight:700;color:var(--text-primary)}.lottery-draw-box.is-drawing .draw-name{animation:drawPulse .6s ease-in-out infinite}.lottery-buttons{display:flex;flex-wrap:wrap;gap:12px}.lottery-results{margin-top:4px}.lottery-empty{color:var(--text-secondary);text-align:center;padding:16px 0}.winner-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;max-height:240px;overflow-y:auto}.winner-item{display:flex;align-items:center;gap:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:10px 14px;color:var(--text-primary)}.winner-index{color:var(--text-secondary);font-weight:600}.winner-name{font-weight:600;flex:1}.winner-prize{color:var(--text-secondary);font-size:.9rem}@keyframes drawPulse{0%{transform:translateY(0)}50%{transform:translateY(-4px)}to{transform:translateY(0)}}@media (max-width: 900px){.lottery-layout{grid-template-columns:1fr}.lottery-buttons{justify-content:center}.prize-row{grid-template-columns:minmax(0,1fr) 90px}.prize-header{display:none}.prize-count{text-align:left}.prize-remove{grid-column:1 / -1;justify-self:flex-end}}.lottery-james-tool{--james-bg: linear-gradient(180deg, #f6fbff 0%, #edf6ff 44%, #fff7ec 100%);--james-stage: linear-gradient(180deg, #d8ecff 0%, #f9fcff 28%, #fff6ea 100%);--james-stage-glow: rgba(255, 210, 126, .34);--james-tree: #2f8b57;--james-tree-dark: #236943;--james-trunk: #7a4f33;--james-gold: #f7c64b;--james-red: #e26d5a;--james-card: rgba(255, 255, 255, .74);--james-card-border: rgba(117, 153, 184, .22);max-width:1320px;margin:0 auto;padding:14px 24px 28px}.lottery-james-layout{display:grid;grid-template-columns:minmax(320px,.92fr) minmax(0,1.4fr);gap:24px;align-items:start}.lottery-james-card{background:var(--james-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:24px;padding:24px;box-shadow:0 18px 46px #48698a1f;border:1px solid var(--james-card-border);display:flex;flex-direction:column;gap:18px}.lottery-james-card-title{margin:0;font-size:1.3rem;color:var(--text-primary)}.lottery-james-stage-card{background:var(--james-bg)}.lottery-james-field{display:flex;flex-direction:column;gap:8px}.lottery-james-field label{font-weight:700;color:var(--text-primary)}.lottery-james-input,.lottery-james-textarea{width:100%;background:#ffffffb8;border:1px solid rgba(145,173,196,.45);color:var(--text-primary);border-radius:14px;padding:12px 14px;font-size:1rem;box-shadow:inset 0 1px #ffffff8c}.lottery-james-input:focus,.lottery-james-textarea:focus{outline:none;border-color:#4e8fcd9e;box-shadow:0 0 0 4px #62a2de1f}.lottery-james-prize-list{display:flex;flex-direction:column;gap:10px}.lottery-james-prize-header,.lottery-james-prize-row{display:grid;grid-template-columns:minmax(0,1fr) 90px auto;gap:10px;align-items:center}.lottery-james-prize-header{font-size:.82rem;letter-spacing:.04em;color:var(--text-secondary);text-transform:uppercase}.lottery-james-prize-input{min-width:0}.lottery-james-prize-count{text-align:center}.lottery-james-prize-remove{white-space:nowrap}.lottery-james-prize-add{align-self:flex-start}.lottery-james-textarea{min-height:180px;resize:vertical}.lottery-james-helper{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--text-secondary);font-size:.92rem}.lottery-james-counts,.lottery-james-actions,.lottery-james-buttons{display:flex;gap:10px 12px;flex-wrap:wrap}.lottery-james-btn{border:none;border-radius:999px;padding:11px 18px;font-size:.96rem;cursor:pointer;font-weight:700;transition:transform .22s ease,box-shadow .22s ease,background .22s ease}.lottery-james-btn.primary{background:linear-gradient(135deg,#e9705a,#f58d61);color:#fff;box-shadow:0 14px 24px #e56d503d}.lottery-james-btn.primary:hover:not(:disabled){transform:translateY(-1px) scale(1.01);box-shadow:0 18px 30px #e56d5052}.lottery-james-btn.secondary{background:#ffffffc7;color:var(--text-primary);border:1px solid rgba(145,173,196,.38)}.lottery-james-btn.secondary:hover:not(:disabled){background:#fffffff2}.lottery-james-btn:disabled{opacity:.58;cursor:not-allowed;transform:none;box-shadow:none}.lottery-james-file-input{display:none}.lottery-james-error{color:#c64b3d;background:#ff7c5f24;border:1px solid rgba(255,124,95,.28);border-radius:14px;padding:11px 13px;font-size:.95rem}.lottery-james-stage-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap}.lottery-james-stage-hint{margin:6px 0 0;color:var(--text-secondary)}.lottery-james-stage-meta{min-width:140px;display:flex;flex-direction:column;gap:6px;padding:12px 14px;border-radius:16px;background:#ffffff9e;border:1px solid rgba(145,173,196,.24)}.lottery-james-stage-meta span,.lottery-james-results-title{color:var(--text-secondary);font-size:.82rem;letter-spacing:.05em;text-transform:uppercase}.lottery-james-stage-meta strong{color:var(--text-primary);font-size:1rem}.lottery-james-stage{position:relative;overflow:hidden;min-height:520px;border-radius:30px;padding:20px;background:radial-gradient(circle at 18% 18%,rgba(255,255,255,.95) 0 10%,transparent 11%),radial-gradient(circle at 80% 10%,rgba(255,255,255,.7) 0 9%,transparent 10%),radial-gradient(circle at 50% 35%,rgba(255,210,126,.28),transparent 54%),var(--james-stage);border:1px solid rgba(162,188,209,.26);box-shadow:inset 0 1px #ffffffa6}.lottery-james-stage:before{content:"";position:absolute;inset:auto 0 0;height:160px;background:radial-gradient(circle at 18% 36%,rgba(255,255,255,.95),transparent 44%),radial-gradient(circle at 46% 18%,rgba(255,255,255,.9),transparent 48%),radial-gradient(circle at 78% 26%,rgba(255,255,255,.92),transparent 46%),linear-gradient(180deg,#fff0,#fefcf8c2 22%,#fff8ef)}.lottery-james-raccoon{position:absolute;left:24px;bottom:76px;width:220px;height:292px;transform-origin:bottom center;z-index:4}.lottery-james-raccoon.is-shaking{animation:jamesRaccoonHop .42s ease-in-out infinite}.lottery-james-raccoon-image{width:100%;height:100%;object-fit:contain;object-position:bottom;filter:drop-shadow(0 14px 20px rgba(61,72,92,.3))}.lottery-james-tree{position:absolute;right:70px;bottom:58px;width:min(54%,420px);height:420px;transform-origin:bottom center;z-index:3}.lottery-james-tree.is-shaking{animation:jamesTreeShake .32s ease-in-out infinite}.lottery-james-tree-label{position:absolute;top:58px;left:50%;transform:translate(-50%);padding:7px 12px;border-radius:999px;font-size:.82rem;font-weight:700;color:#1d5f3a;background:#ffffffb8;z-index:2}.lottery-james-tree-star{position:absolute;left:50%;top:18px;width:30px;height:30px;background:var(--james-gold);clip-path:polygon(50% 0%,61% 35%,98% 35%,67% 56%,79% 92%,50% 69%,21% 92%,33% 56%,2% 35%,39% 35%);transform:translate(-50%);filter:drop-shadow(0 0 12px rgba(247,198,75,.75));z-index:2}.lottery-james-tree-layer{position:absolute;left:50%;transform:translate(-50%);background:linear-gradient(180deg,#46aa70 0%,var(--james-tree) 52%,var(--james-tree-dark) 100%);clip-path:polygon(50% 0%,100% 100%,0% 100%);filter:drop-shadow(0 12px 18px rgba(35,105,67,.16))}.lottery-james-tree-layer.layer-top{top:52px;width:190px;height:160px}.lottery-james-tree-layer.layer-middle{top:124px;width:270px;height:210px}.lottery-james-tree-layer.layer-bottom{top:224px;width:350px;height:240px}.lottery-james-tree-trunk{position:absolute;left:50%;bottom:0;width:70px;height:112px;transform:translate(-50%);border-radius:18px;background:linear-gradient(180deg,#9a6847,var(--james-trunk))}.lottery-james-ornaments{position:absolute;top:92px;right:54px;bottom:48px;left:54px;z-index:2}.lottery-james-ornament{position:absolute;left:var(--ornament-x);top:var(--ornament-y);width:92px;min-height:52px;padding:18px 10px 10px;border-radius:18px;background:linear-gradient(180deg,#fffcf2f5,#fff1d6eb);color:#4b3820;font-size:.8rem;font-weight:700;line-height:1.2;text-align:center;box-shadow:0 10px 20px #5e4d2c2e;transform:translate(-50%,-50%) rotate(calc((var(--ornament-x) - 35%) / 6));animation:jamesOrnamentFloat 2.2s ease-in-out infinite;animation-delay:var(--ornament-delay)}.lottery-james-ornament:before{content:"";position:absolute;top:-16px;left:50%;width:2px;height:18px;background:#795e379e;transform:translate(-50%)}.lottery-james-ornament:after{content:"";position:absolute;top:-2px;left:50%;width:16px;height:10px;border:2px solid rgba(121,94,55,.72);border-bottom:none;border-radius:999px 999px 0 0;transform:translate(-50%)}.lottery-james-ornament.is-selected{opacity:.08}.lottery-james-falling-card{position:absolute;left:clamp(290px,42%,440px);top:102px;width:140px;min-height:90px;padding:16px 14px;display:flex;flex-direction:column;gap:6px;justify-content:center;text-align:center;color:#4f3822;border-radius:22px;background:linear-gradient(180deg,#fffdf6,#ffe8bb);border:1px solid rgba(181,139,60,.28);box-shadow:0 22px 28px #835f1c29;z-index:6;animation:jamesWinnerDrop 1.45s cubic-bezier(.14,.8,.18,1) forwards}.lottery-james-falling-label{font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:#8c6640}.lottery-james-spotlight{position:absolute;left:20px;right:20px;bottom:26px;display:flex;flex-direction:column;gap:6px;align-items:center;padding:20px 18px;border-radius:24px;background:radial-gradient(circle at 50% 0%,var(--james-stage-glow),rgba(255,255,255,0) 58%),#ffffff9e;border:1px solid rgba(145,173,196,.2);z-index:5}.lottery-james-spotlight span{color:var(--text-secondary);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase}.lottery-james-spotlight strong{font-size:clamp(1.2rem,2vw,2rem);color:var(--text-primary)}.lottery-james-spotlight.is-active strong{animation:jamesWinnerPulse .7s ease-in-out 2}.lottery-james-stage-snow span{position:absolute;top:-18px;width:10px;height:10px;border-radius:50%;background:#ffffffeb;box-shadow:0 0 12px #ffffffbf;animation:jamesSnowFall linear infinite}.lottery-james-stage-snow span:nth-child(1){left:10%;animation-duration:7s}.lottery-james-stage-snow span:nth-child(2){left:28%;animation-duration:9s;animation-delay:-1s}.lottery-james-stage-snow span:nth-child(3){left:56%;animation-duration:8s;animation-delay:-2.5s}.lottery-james-stage-snow span:nth-child(4){left:76%;animation-duration:10s;animation-delay:-4.2s}.lottery-james-stage-snow span:nth-child(5){left:90%;animation-duration:6.6s;animation-delay:-3.1s}.lottery-james-results{display:flex;flex-direction:column;gap:10px}.lottery-james-empty{color:var(--text-secondary);text-align:center;padding:16px 0}.lottery-james-winner-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;max-height:280px;overflow-y:auto}.lottery-james-winner-item{display:flex;align-items:center;gap:12px;background:#fffc;border:1px solid rgba(145,173,196,.28);border-radius:16px;padding:12px 14px;color:var(--text-primary)}.lottery-james-winner-index{color:#dd7b58;font-weight:700}.lottery-james-winner-name{font-weight:700;flex:1}.lottery-james-winner-prize{color:var(--text-secondary);font-size:.92rem}@keyframes jamesRaccoonHop{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-6px) rotate(-4deg)}75%{transform:translateY(-4px) rotate(4deg)}}@keyframes jamesTreeShake{0%,to{transform:rotate(0)}25%{transform:rotate(-2.8deg)}50%{transform:rotate(2.5deg)}75%{transform:rotate(-1.8deg)}}@keyframes jamesOrnamentFloat{0%,to{transform:translate(-50%,-50%) rotate(-3deg)}50%{transform:translate(-50%,calc(-50% - 4px)) rotate(3deg)}}@keyframes jamesWinnerDrop{0%{transform:translateY(-12px) rotate(-9deg) scale(.92);opacity:0}15%{opacity:1}78%{transform:translateY(320px) rotate(9deg) scale(1.02);opacity:1}to{transform:translateY(360px) rotate(0) scale(1);opacity:1}}@keyframes jamesWinnerPulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes jamesSnowFall{0%{transform:translateY(0) translate(0);opacity:0}10%{opacity:.95}to{transform:translateY(680px) translate(30px);opacity:0}}@media (max-width: 1100px){.lottery-james-layout{grid-template-columns:1fr}.lottery-james-stage{min-height:500px}.lottery-james-tree{right:36px;width:min(56%,380px);height:380px}}@media (max-width: 760px){.lottery-james-tool{padding:20px 14px 32px}.lottery-james-stage{min-height:620px;padding:16px}.lottery-james-raccoon{left:50%;bottom:58px;width:192px;height:256px;transform:translate(-136px)}.lottery-james-tree{left:50%;right:auto;bottom:170px;width:min(94%,330px);height:340px;transform:translate(-50%)}.lottery-james-tree.is-shaking{animation:jamesTreeShakeMobile .32s ease-in-out infinite}.lottery-james-falling-card{left:50%;top:112px;transform:translate(-50%)}.lottery-james-prize-row{grid-template-columns:minmax(0,1fr) 90px}.lottery-james-prize-header{display:none}.lottery-james-prize-remove{grid-column:1 / -1;justify-self:flex-end}}@media (max-width: 520px){.lottery-james-stage{min-height:660px}.lottery-james-raccoon{width:164px;height:220px;transform:translate(-95px) scale(.9);transform-origin:bottom center}.lottery-james-ornament{width:78px;min-height:46px;font-size:.72rem}.lottery-james-buttons{flex-direction:column}.lottery-james-btn{width:100%;justify-content:center}}@keyframes jamesTreeShakeMobile{0%,to{transform:translate(-50%) rotate(0)}25%{transform:translate(-50%) rotate(-2.8deg)}50%{transform:translate(-50%) rotate(2.5deg)}75%{transform:translate(-50%) rotate(-1.8deg)}}.crawl-104{--bg: #f4f1ec;--surface: #ffffff;--ink: #1c1c1f;--muted: #6c6760;--line: #e1d8cf;--accent: #ff6b35;--accent-dark: #d44d1f;--accent-2: #2ec4b6;--shadow: 0 18px 45px rgba(22, 22, 26, .12);font-family:Noto Sans TC,sans-serif;color:var(--ink);background:radial-gradient(circle at 10% 20%,rgba(46,196,182,.18),transparent 45%),radial-gradient(circle at 80% 0%,rgba(255,107,53,.2),transparent 50%),var(--bg);min-height:100vh;position:relative;overflow:hidden;isolation:isolate}.crawl-104:before,.crawl-104:after{content:"";position:absolute;z-index:-1;width:320px;height:320px;border-radius:50%;filter:blur(0px);opacity:.25}.crawl-104:before{background:#ff6b352e;top:-120px;right:-80px}.crawl-104:after{background:#2ec4b633;bottom:-160px;left:-120px}.crawl-104 *{box-sizing:border-box}.crawl-104 .page{max-width:1200px;margin:0 auto;padding:48px 24px 72px}.crawl-104 .hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;align-items:center}.crawl-104 .hero-text h1{font-family:Space Grotesk,sans-serif;font-size:clamp(2rem,3.5vw,3.2rem);margin:12px 0 16px;line-height:1.1}.crawl-104 .eyebrow{font-size:.95rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-dark);margin:0}.crawl-104 .subtitle{font-size:1.05rem;color:var(--muted);margin:0}.crawl-104 .hero-card{background:var(--surface);padding:28px;border-radius:20px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.7);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.crawl-104 form{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px 18px}.crawl-104 .field{display:flex;flex-direction:column;gap:8px;position:relative}.crawl-104 .field.full{grid-column:1 / -1}.crawl-104 label{font-size:.85rem;color:var(--muted)}.crawl-104 input,.crawl-104 select{padding:10px 12px;border-radius:10px;border:1px solid var(--line);font-size:.95rem;font-family:inherit;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.crawl-104 input:focus,.crawl-104 select:focus{outline:none;border-color:var(--accent-2);box-shadow:0 0 0 3px #2ec4b62e}.crawl-104 .hint{font-size:.75rem;color:var(--muted)}.crawl-104 .actions{display:flex;gap:12px;align-items:center;grid-column:1 / -1}.crawl-104 button{border:none;border-radius:999px;padding:10px 18px;font-size:.95rem;font-weight:600;font-family:Space Grotesk,sans-serif;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.crawl-104 button.primary{background:var(--accent);color:#fff;box-shadow:0 10px 25px #ff6b3559}.crawl-104 button.primary:hover{background:var(--accent-dark);transform:translateY(-1px)}.crawl-104 button.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}.crawl-104 button.ghost:hover{border-color:var(--accent-2);color:var(--accent-2)}.crawl-104 button:disabled{cursor:not-allowed;opacity:.6;box-shadow:none}.crawl-104 .note{margin:6px 0 0;font-size:.8rem;color:var(--muted);grid-column:1 / -1}.crawl-104 .status{margin:40px 0 24px}.crawl-104 .status-card{background:var(--surface);padding:20px 24px;border-radius:16px;border:1px solid var(--line);display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;align-items:center}.crawl-104 .progress{margin-bottom:24px}.crawl-104 .progress-card{background:var(--surface);border-radius:16px;border:1px solid var(--line);padding:18px 22px;display:grid;gap:18px;box-shadow:var(--shadow)}.crawl-104 .progress-group{display:grid;gap:10px}.crawl-104 .progress-label{display:flex;justify-content:space-between;font-size:.85rem;color:var(--muted)}.crawl-104 .progress-bar{position:relative;height:12px;background:#e1d8cf80;border-radius:999px;overflow:hidden}.crawl-104 .progress-fill{position:absolute;top:0;right:0;bottom:0;left:0;width:0%;background:var(--accent-2);transition:width .25s ease}.crawl-104 .progress-fill.accent{background:var(--accent)}.crawl-104 .logs{margin-bottom:32px}.crawl-104 .log-card{background:var(--surface);border-radius:16px;border:1px solid var(--line);padding:18px 22px;box-shadow:var(--shadow)}.crawl-104 .log-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.crawl-104 .log-header h3{margin:0;font-family:Space Grotesk,sans-serif;font-size:1.1rem}.crawl-104 .log-header button{width:auto}.crawl-104 .log-list{max-height:220px;overflow:auto;display:grid;gap:6px;font-size:.85rem;color:var(--muted)}.crawl-104 .log-item{display:flex;gap:12px;align-items:center;padding:6px 10px;background:#f4f1ecb3;border-radius:10px}.crawl-104 .log-time{font-family:Space Grotesk,sans-serif;font-size:.75rem;color:var(--accent-dark)}.crawl-104 .log-empty{margin:0;color:var(--muted)}.crawl-104 .small{padding:6px 12px;font-size:.8rem}.crawl-104 .status-title{margin:0;font-size:.85rem;color:var(--muted)}.crawl-104 .status-message{margin:6px 0 0;font-family:Space Grotesk,sans-serif;font-size:1.2rem}.crawl-104 .stats{display:flex;gap:18px;flex-wrap:wrap}.crawl-104 .stat{background:#2ec4b61f;padding:10px 14px;border-radius:12px;min-width:90px}.crawl-104 .stat .label{display:block;font-size:.75rem;color:var(--muted)}.crawl-104 .stat .value{font-size:1.1rem;font-weight:600}.crawl-104 .results-header{display:flex;align-items:baseline;justify-content:space-between;gap:16px}.crawl-104 .results-header h2{font-family:Space Grotesk,sans-serif;font-size:1.5rem;margin:0}.crawl-104 .results-header p{margin:0;color:var(--muted)}.crawl-104 .table-wrap{margin-top:16px;background:var(--surface);border-radius:18px;border:1px solid var(--line);overflow:auto;max-height:520px;box-shadow:var(--shadow)}.crawl-104 table{width:max-content;min-width:100%;border-collapse:collapse;font-size:.9rem}.crawl-104 thead th{position:sticky;top:0;background:#fdfaf7;text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);font-size:.8rem;color:var(--muted);z-index:1}.crawl-104 tbody td{padding:12px 14px;border-bottom:1px solid rgba(225,216,207,.7);vertical-align:top}.crawl-104 tbody tr:nth-child(2n){background:#f4f1ec8c}.crawl-104 tbody a{color:var(--accent-dark);text-decoration:none}.crawl-104 tbody a:hover{text-decoration:underline}.crawl-104 .job-list{display:grid;gap:8px;width:max-content}.crawl-104 .job-item{display:grid;gap:4px;padding:8px 10px;background:#f4f1ecb3;border-radius:10px;width:max-content}.crawl-104 .job-line{display:flex;flex-wrap:nowrap;gap:8px;align-items:baseline;white-space:nowrap;width:max-content}.crawl-104 .job-title{font-weight:600;display:inline-block;min-width:15ch;white-space:nowrap}.crawl-104 .job-cell{min-width:32ch}.crawl-104 .industry-cell{min-width:36ch;max-width:70ch;white-space:normal;line-height:1.5}.crawl-104 .job-date{font-size:.75rem;color:var(--muted)}.crawl-104 .job-link{font-size:.8rem;color:var(--accent-dark)}.crawl-104 .ellipsis{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@keyframes crawl104-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.crawl-104 .hero-text,.crawl-104 .hero-card,.crawl-104 .status-card,.crawl-104 .results{animation:crawl104-rise .7s ease both}.crawl-104 .hero-card{animation-delay:.15s}.crawl-104 .status-card{animation-delay:.25s}.crawl-104 .results{animation-delay:.35s}@media (max-width: 768px){.crawl-104 .page{padding:32px 18px 56px}.crawl-104 .status-card{flex-direction:column;align-items:flex-start}.crawl-104 .actions{flex-direction:column;align-items:stretch}.crawl-104 button{width:100%}}.chat-tool{max-width:1200px;margin:0 auto;padding:24px}.chat-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:24px}.chat-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:start}.chat-panel,.chat-sidebar{display:flex;flex-direction:column;gap:16px}.chat-card{background:var(--bg-primary);border-radius:16px;padding:24px;box-shadow:var(--shadow-md);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:16px}.chat-card h3{margin:0;font-size:1.2rem;color:var(--text-primary)}.chat-muted{color:var(--text-secondary);font-size:.95rem}.chat-field{display:flex;flex-direction:column;gap:8px}.chat-field label{font-weight:600;color:var(--text-primary)}.chat-input{width:100%;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:10px;padding:10px 12px;font-size:1rem}.chat-textarea{min-height:44px;resize:none;line-height:1.4}.chat-btn{border:none;border-radius:10px;padding:10px 16px;font-size:.95rem;cursor:pointer;font-weight:600;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.chat-btn.primary{background:var(--accent-color);color:#fff}.chat-btn.primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 16px #2196f34d}.chat-btn.secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.chat-btn.secondary:hover{background:var(--border-color)}.chat-status{color:var(--text-secondary);font-size:.9rem}.chat-status.error{color:#e53935;font-weight:600}.chat-room-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-radius:14px;border:1px solid var(--border-color);background:var(--bg-primary);box-shadow:var(--shadow-sm)}.chat-room-code{font-size:1.1rem;font-weight:700}.chat-room-status{color:var(--text-secondary);font-size:.9rem}.chat-room-participants{font-size:.95rem;font-weight:600}.chat-messages{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:20px;height:460px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.chat-empty{color:var(--text-secondary);text-align:center;margin-top:40px}.chat-message{display:flex;flex-direction:column;gap:6px}.chat-message.self{align-items:flex-end}.chat-message-meta{display:flex;gap:8px;font-size:.85rem;color:var(--text-secondary)}.chat-bubble{background:var(--bg-secondary);border-radius:12px;padding:12px 14px;max-width:90%;border:1px solid var(--border-color)}.chat-message.self .chat-bubble{background:#2196f31f;border-color:#2196f34d}.chat-text{margin:0;white-space:pre-wrap;color:var(--text-primary)}.chat-read{font-size:.75rem;color:var(--text-secondary)}.chat-file{display:flex;flex-direction:column;gap:8px}.chat-file img,.chat-file video{max-width:100%;border-radius:12px;border:1px solid var(--border-color)}.chat-file-link{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-primary)}.chat-download{align-self:flex-start;color:var(--accent-color);font-weight:600;text-decoration:none}.chat-input-bar{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center}.chat-file-input{display:none}.chat-share-row{display:flex;gap:8px;align-items:center}.chat-share-row .chat-input{flex:1}.chat-qr{width:220px;border-radius:12px;border:1px solid var(--border-color);background:#fff}.chat-hint{font-size:.85rem;color:var(--text-secondary)}.chat-members{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.chat-member{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-secondary)}.chat-member-name{font-weight:600;color:var(--text-primary)}@media (max-width: 960px){.chat-layout{grid-template-columns:minmax(0,1fr)}.chat-messages{height:380px}.chat-input-bar{grid-template-columns:1fr}.chat-btn{width:100%}.chat-share-row{flex-direction:column}}@media (max-width: 600px){.chat-tool,.chat-card,.chat-messages{padding:16px}.chat-qr{width:180px}}.vote-tool{min-height:100%;padding:40px 24px 56px;background:radial-gradient(circle at top left,rgba(255,209,102,.28),transparent 28%),radial-gradient(circle at top right,rgba(103,80,164,.2),transparent 22%),linear-gradient(180deg,#fff8ea,#f4f8ff 52%,#eef4ff);color:#1e2432}.vote-tool-result{padding:0;background:radial-gradient(circle at 20% 20%,rgba(255,215,0,.16),transparent 25%),linear-gradient(135deg,#111827,#1f2937 60%,#0f172a);color:#f8fafc}.vote-hero-card,.vote-room-layout{width:min(1180px,100%);margin:0 auto}.vote-hero-card{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:start}.vote-hero-copy,.vote-create-panel,.vote-main-panel,.vote-share-card{border:1px solid rgba(30,36,50,.08);border-radius:28px;background:#ffffffd1;box-shadow:0 24px 70px #1f29371f;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.vote-hero-copy{padding:48px;min-height:100%}.vote-hero-copy h1,.vote-panel-head h1,.vote-race-head h1{margin:14px 0 12px;font-size:clamp(2rem,4vw,4.2rem);line-height:.95}.vote-hero-copy p,.vote-panel-head p,.vote-race-head p{margin:0;color:#576074;font-size:1.02rem}.vote-create-panel,.vote-main-panel{padding:28px}.vote-create-panel label,.vote-card-stack label{display:grid;gap:8px;margin-bottom:16px;font-weight:700}.vote-create-panel input,.vote-card-stack input,.vote-option-row input{width:100%;border:1px solid rgba(86,96,116,.2);border-radius:16px;padding:14px 16px;font-size:1rem;background:#ffffffeb}.vote-option-editor{display:grid;gap:10px;margin-bottom:16px}.vote-option-row{display:grid;grid-template-columns:1fr auto;gap:10px}.vote-option-row button,.vote-secondary{border:1px solid rgba(30,36,50,.14);border-radius:16px;background:#fffc;padding:0 16px;cursor:pointer;font-weight:700}.vote-primary{border:0;border-radius:18px;background:linear-gradient(135deg,#ef4444,#f59e0b);color:#fff;padding:15px 18px;font-size:1rem;font-weight:800;cursor:pointer;box-shadow:0 16px 32px #ef444440}.vote-primary:disabled,.vote-secondary:disabled{opacity:.6;cursor:not-allowed}.vote-inline-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:16px}.vote-toggle{display:inline-flex;align-items:center;gap:10px;font-weight:700}.vote-chip{display:inline-flex;align-items:center;border-radius:999px;padding:8px 14px;background:#ef44441a;color:#b91c1c;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.vote-banner{width:min(1180px,100%);margin:0 auto 18px;border-radius:18px;padding:14px 18px;font-weight:700}.vote-banner.error{background:#fee2e2;color:#991b1b}.vote-banner.success{background:#dcfce7;color:#166534}.vote-room-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:24px}.vote-panel-head,.vote-dashboard-topline,.vote-share-card{display:grid;gap:12px}.vote-panel-head{grid-template-columns:1fr auto;gap:18px;align-items:start;margin-bottom:22px}.vote-expiry{font-weight:700;color:#6b7280}.vote-card-stack,.vote-dashboard{display:grid;gap:18px}.vote-add-option-card{display:grid;gap:12px;padding:16px;border-radius:18px;background:#ffffffe0;border:1px dashed rgba(30,36,50,.16)}.vote-add-option-card label{margin-bottom:0}.vote-choice-list,.vote-host-list{display:grid;gap:12px}.vote-choice{width:100%;border:1px solid rgba(31,41,55,.1);border-radius:20px;padding:18px 20px;background:#fff;display:flex;justify-content:space-between;align-items:center;cursor:pointer;text-align:left}.vote-choice.active{border-color:#ef4444;box-shadow:inset 0 0 0 2px #ef44442e;background:#fff7ed}.vote-dashboard-topline{grid-template-columns:repeat(3,minmax(0,1fr))}.vote-dashboard-topline>div{padding:16px 18px;border-radius:20px;background:linear-gradient(180deg,#fffffffa,#f8fafcd6)}.vote-dashboard-topline strong{display:block;font-size:1.5rem;margin-bottom:6px}.vote-host-option{border-radius:20px;padding:16px 18px;background:#ffffffeb}.vote-host-option.leader{outline:2px solid rgba(245,158,11,.35)}.vote-host-label{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px}.vote-host-bar{height:14px;border-radius:999px;overflow:hidden;background:#e5e7eb}.vote-host-bar div{height:100%;border-radius:inherit;background:linear-gradient(90deg,#ef4444,#f59e0b)}.vote-share-panel{display:grid;gap:18px}.vote-share-card{padding:22px}.vote-share-card.accent{background:linear-gradient(180deg,#111827f0,#1f2937eb);color:#f8fafc}.vote-share-card a{color:inherit;word-break:break-all}.vote-share-card img{width:180px;max-width:100%;border-radius:16px;background:#fff;padding:8px}.vote-race-board{min-height:100vh;padding:48px 24px 56px;width:min(1180px,100%);margin:0 auto}.vote-race-head{text-align:center;margin-bottom:34px}.vote-race-head p{color:#e2e8f0d6}.vote-race-list{display:grid;gap:18px}.vote-race-status{margin:22px 0 0;text-align:center;color:#e2e8f0e0;font-weight:700;letter-spacing:.04em}.vote-racer{border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:18px 20px 22px;background:#0f172aad}.vote-racer.winner{box-shadow:0 0 0 2px #facc1573}.vote-racer-meta{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;margin-bottom:14px}.vote-racer-rank{font-weight:900;color:#fbbf24}.vote-track{position:relative;height:26px;border-radius:999px;background:#94a3b838;overflow:hidden}.vote-track-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#38bdf8,#facc15);transition:width .2s linear}.vote-track-runner{position:absolute;top:50%;width:28px;height:28px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#fff,#f97316 66%,#7c2d12);transform:translate(-50%,-50%);box-shadow:0 0 24px #f9731680;transition:left .2s linear}.vote-result-waiting{min-height:52vh;display:grid;place-items:center;gap:16px;text-align:center}.vote-countdown-pulse{width:92px;height:92px;border-radius:50%;background:radial-gradient(circle,#facc15e0,#f59e0b33);animation:votePulse 1.6s ease-in-out infinite}@keyframes votePulse{0%,to{transform:scale(.9);opacity:.72}50%{transform:scale(1.08);opacity:1}}@media (max-width: 960px){.vote-hero-card,.vote-room-layout,.vote-dashboard-topline,.vote-panel-head{grid-template-columns:1fr}}@media (max-width: 640px){.vote-tool,.vote-race-board{padding-left:16px;padding-right:16px}.vote-hero-copy,.vote-create-panel,.vote-main-panel,.vote-share-card{padding:20px;border-radius:22px}.vote-racer-meta{grid-template-columns:1fr}}.version-badge{position:fixed;right:12px;bottom:12px;z-index:9999;font-size:12px;line-height:1;padding:6px 8px;border-radius:999px;color:#ffffffeb;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);-webkit-user-select:none;user-select:none;pointer-events:none}.dark-mode .version-badge{background:#ffffff2e}.quiz-game-tool{min-height:100vh;width:100%;margin:0 auto;padding:clamp(16px,2.4vw,28px);color:#eef4ff;box-sizing:border-box;background:radial-gradient(circle at 10% 10%,#172554,#0b1020 45%,#06070e);font-family:Noto Sans TC,PingFang TC,Microsoft JhengHei,Hiragino Sans CNS,Arial,sans-serif;position:relative;overflow-x:hidden}.quiz-game-tool:before{content:"";position:absolute;inset:-20% auto auto -10%;width:520px;aspect-ratio:1;background:radial-gradient(circle,rgba(56,189,248,.16),transparent 63%);pointer-events:none;z-index:0}.quiz-game-tool:after{content:"";position:absolute;inset:auto -12% -15% auto;width:470px;aspect-ratio:1;background:radial-gradient(circle,rgba(251,191,36,.16),transparent 63%);pointer-events:none;z-index:0}.quiz-tool-header,.quiz-screen,.quiz-card,.quiz-hero{position:relative;z-index:1}.quiz-tool-header{margin-bottom:14px;display:flex;flex-direction:column;gap:10px}.quiz-tool-header h2{margin:0;font-size:clamp(1.5rem,2.8vw,2.2rem);letter-spacing:.06em;text-transform:none}.quiz-tool-header p{margin:0;color:#a8b8d8;font-size:.96rem}.quiz-connection-status{margin-top:8px!important;color:#9cc8ff;font-weight:700;letter-spacing:.02em;display:inline-flex;align-items:center;gap:8px}.quiz-connection-status:before{content:"";width:8px;height:8px;border-radius:999px;background:#22d3ee;display:inline-block;animation:pulse-dot 1.6s infinite}.quiz-status{margin:8px 0 0;border:1px solid;border-radius:12px;padding:10px 12px;display:inline-flex;align-items:center;gap:6px;width:fit-content;max-width:100%;word-break:break-word;font-weight:600;letter-spacing:.015em;animation:pop-in .2s ease}.quiz-status-info{color:#38bdf8;border-color:#38bdf873;background:#38bdf824}.quiz-status-success{color:#4ade80;border-color:#4ade8073;background:#4ade8021}.quiz-status-error{color:#fb7185;border-color:#fb718573;background:#fb718529}.quiz-top-band{display:flex;flex-wrap:wrap;gap:8px}.quiz-status-badge{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(148,163,184,.35);border-radius:999px;padding:6px 10px;color:#e2e8ff;font-weight:700;font-size:.82rem;background:#0f172a73;letter-spacing:.02em}.quiz-status-badge-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .15s ease}.quiz-status-badge-btn:hover{background:#1e293bc7;border-color:#7dd3fc7a}.quiz-status-badge-btn:active{transform:translateY(1px)}.quiz-screen{width:100%;display:flex;flex-direction:column;gap:14px;animation:fade-in .35s ease;min-height:100vh;padding:18px;box-sizing:border-box}.quiz-screen-ppt{padding:24px clamp(16px,4vw,40px);gap:16px}.quiz-ppt-main{display:grid;grid-template-columns:1fr;gap:16px}.quiz-ppt-hero{border-radius:22px;padding:18px 20px;background:linear-gradient(125deg,#7dd3fc47,#0ea5e933);border:1px solid rgba(186,230,253,.55);box-shadow:0 20px 48px #060a1f73}.quiz-ppt-hero h2{margin:0 0 8px;font-size:clamp(1.6rem,2.8vw,2.4rem);line-height:1.25}.quiz-ppt-hero p{margin:0;font-size:clamp(1rem,1.7vw,1.3rem);color:#dbeafe}.quiz-ppt-board{background:#0e192bd6;border:1px solid rgba(148,163,184,.4);border-radius:24px;min-height:46vh;padding:22px;display:flex;align-items:center;justify-content:center;box-sizing:border-box;box-shadow:inset 0 0 0 1px #94a3b833,0 18px 42px #02061766}.quiz-ppt-state{width:100%;max-width:1100px;text-align:center}.quiz-screen-wait-join{margin:22px auto 0;width:min(540px,100%);display:flex;flex-direction:column;align-items:center;gap:14px}.quiz-screen-join-link{margin:0;color:#f8fafc;word-break:break-all;background:#0f172ab8;border:1px solid rgba(148,163,184,.45);border-radius:14px;padding:10px 12px;width:100%;box-sizing:border-box;text-align:center}.quiz-screen-qrcode-wrap{padding:14px;border-radius:16px;background:#fffffff0;width:fit-content;border:1px solid rgba(148,163,184,.5);box-shadow:0 10px 22px #02061759}.quiz-screen-qrcode{width:220px;height:220px;max-width:65vw;display:block;image-rendering:pixelated;background:#fff}.quiz-ppt-state h1{margin:0 0 12px;font-size:clamp(1.8rem,3.8vw,3.2rem);letter-spacing:.03em;line-height:1.25}.quiz-ppt-state p{margin:8px 0;font-size:clamp(1.05rem,2.1vw,1.6rem);color:#dbeafe}.quiz-ppt-state .quiz-timer{height:12px;border-radius:999px}.quiz-timer-caption{margin-top:8px!important;margin-bottom:12px!important;color:#86efac!important}.quiz-option-disabled{border:1px dashed rgba(148,163,184,.4);background:#08101fe6;color:#e5ecff;border-radius:14px;padding:14px;min-height:64px;text-align:left;display:flex;gap:12px;align-items:center;justify-content:flex-start;font-size:1.06rem}.quiz-option-disabled .quiz-option-index{width:30px;height:30px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(148,163,184,.45);color:#dbeafe;font-size:.92rem}.quiz-question-media{width:100%;display:flex;flex-direction:column;gap:10px;margin:10px 0 12px}.quiz-question-image{width:100%;max-height:340px;object-fit:contain;border-radius:14px;border:1px solid rgba(148,163,184,.35);background:#0206178c}.quiz-question-video-wrap{width:100%;border-radius:14px;overflow:hidden;border:1px solid rgba(148,163,184,.35);background:#020617c7}.quiz-question-video{width:100%;aspect-ratio:16 / 9;border:0;display:block}.quiz-question-media-screen .quiz-question-image{max-height:420px}.quiz-screen-ppt .quiz-scoreboard{grid-template-columns:1fr}.quiz-screen-ppt .quiz-card{min-height:300px}.quiz-screen-top5-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;background:radial-gradient(circle at 50% 25%,#0f172ab8,#020617e0);animation:top5-overlay-in .35s ease;pointer-events:none}.quiz-screen-top5-panel{width:min(920px,92vw);border-radius:24px;padding:22px;border:1px solid rgba(125,211,252,.45);background:linear-gradient(130deg,#082f49d6,#1e293be0);box-shadow:0 28px 60px #0f172a80}.quiz-screen-top5-kicker{margin:0 0 8px;font-weight:800;color:#7dd3fc;letter-spacing:.1em;text-transform:uppercase}.quiz-screen-top5-panel h2{margin:0 0 14px;font-size:clamp(1.35rem,2.6vw,2rem)}.quiz-screen-top5-list{display:grid;gap:10px}.quiz-screen-top5-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:14px;border:1px solid rgba(148,163,184,.35);background:#0f172abd;animation:top5-item-in .42s ease}.quiz-screen-top5-item.is-up{border-color:#4ade8080;box-shadow:inset 0 0 0 1px #4ade8040}.quiz-screen-top5-item.is-down{border-color:#fb718580;box-shadow:inset 0 0 0 1px #fb718533}.quiz-screen-top5-item.is-new{border-color:#fbbf249e;box-shadow:inset 0 0 0 1px #fbbf2440}.quiz-screen-top5-left,.quiz-screen-top5-right{display:flex;align-items:center;gap:10px}.quiz-screen-top5-rank{min-width:52px;color:#7dd3fc;font-weight:900}.quiz-screen-top5-name{font-size:1.05rem;font-weight:700}.quiz-screen-top5-score{min-width:76px;text-align:right;font-weight:800}.quiz-screen-top5-trend{border-radius:999px;padding:3px 9px;font-size:.78rem;font-weight:800}.quiz-screen-top5-trend.up{color:#86efac;border:1px solid rgba(74,222,128,.5);background:#14532d80}.quiz-screen-top5-trend.down{color:#fda4af;border:1px solid rgba(251,113,133,.5);background:#4c051973}.quiz-screen-top5-trend.same{color:#cbd5e1;border:1px solid rgba(148,163,184,.45)}.quiz-screen-top5-trend.new{color:#fde68a;border:1px solid rgba(251,191,36,.58);background:#78350f73;animation:top5-new-pulse 1.1s ease-in-out infinite}.quiz-screen-ppt .quiz-leaderboard-item{min-height:56px}.quiz-screen-ppt .quiz-rank{min-width:34px;font-size:1.05rem}.quiz-screen-ppt .quiz-name{font-size:1.05rem}.quiz-screen-mode{gap:16px}.quiz-screen-layout{grid-template-columns:1.35fr 1fr;align-items:start}.quiz-hero-screen{background:linear-gradient(110deg,#0ea5e947,#10b98133);border-color:#7dd3fc80;box-shadow:0 18px 38px #0ea5e947}.quiz-screen-mode .quiz-room-header h3{color:#cffafe}.quiz-screen-stage-tag{margin:6px 0;display:inline-flex;padding:6px 10px;border-radius:999px;color:#e2e8ff;border:1px solid rgba(125,211,252,.45);background:#0f172a5c;font-size:.84rem;font-weight:700}.quiz-hero{border-radius:18px;padding:16px;background:linear-gradient(120deg,#38bdf833,#a78bfa33);border:1px solid rgba(148,163,184,.35);box-shadow:0 14px 35px #0508184d}.quiz-hero h2,.quiz-hero h3{margin:0 0 6px;letter-spacing:.04em}.quiz-hero p{margin:0;color:#e2e8f0;letter-spacing:.01em}.quiz-card{background:#101828b8;border:1px solid rgba(148,163,184,.28);border-radius:18px;padding:16px;box-shadow:0 10px 28px #02082047;display:flex;flex-direction:column;gap:12px;box-sizing:border-box;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.quiz-card h3{margin:0;color:#f1f5ff}.quiz-host-layout{display:grid;grid-template-columns:1.25fr 1fr;gap:14px}.quiz-player-layout{display:grid;gap:12px}.quiz-player-main{min-height:320px;border-left:2px solid rgba(96,165,250,.45)}.quiz-player-main,.quiz-leaderboard,.quiz-wait,.quiz-question,.quiz-question .quiz-option{animation:rise-in .45s ease}.quiz-field{display:flex;flex-direction:column;gap:7px}.quiz-field label{color:#d7e0f8;font-weight:600}.quiz-input,.quiz-textarea{width:100%;background:#070c19e6;color:#f8fbff;border:1px solid rgba(148,163,184,.35);border-radius:12px;padding:11px 13px;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.quiz-input:focus,.quiz-textarea:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #38bdf83d}.quiz-input.quiz-input-error,.quiz-textarea.quiz-input-error{border-color:#fb7185}.quiz-error{margin:0;font-size:.85rem;color:#fb7185}.quiz-textarea{min-height:180px;resize:vertical;font-family:inherit}.quiz-row{display:grid;grid-template-columns:1fr}.quiz-actions{display:flex;gap:8px;flex-wrap:wrap}.quiz-btn{border:none;border-radius:12px;padding:10px 16px;cursor:pointer;font-weight:700;color:#fff;transition:transform .12s ease,filter .2s ease,box-shadow .2s ease;letter-spacing:.02em}.quiz-btn:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.08)}.quiz-btn:active:not(:disabled){transform:translateY(0)}.quiz-btn.primary{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 8px 18px #2563eb54}.quiz-btn.secondary{background:linear-gradient(135deg,#64748b,#334155)}.quiz-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;filter:grayscale(.2)}.quiz-room-header,.quiz-room-meta,.quiz-leaderboard,.quiz-meta-grid{display:flex;flex-direction:column;gap:8px}.quiz-room-header{display:flex;justify-content:space-between;align-items:baseline}.quiz-room-meta{gap:4px}.quiz-label{color:#9fb1cf;margin-right:8px}.quiz-copy{border:none;background:transparent;color:#7dd3fc;cursor:pointer;text-decoration:underline;padding:0}.quiz-copy-status{display:inline-flex;align-items:center;margin-left:6px;color:#86efac;font-size:.85rem;font-weight:700}.quiz-hint{margin:0;font-size:.85rem;color:#b7c6e3}.quiz-meta-grid{gap:8px;grid-template-columns:1fr 1fr;border-radius:10px;padding:10px;background:#0f172a61}.quiz-scoreboard{display:grid;grid-template-columns:1.35fr 1fr;gap:12px}.quiz-player-screen .quiz-scoreboard{grid-template-columns:1fr}.quiz-game-stats{display:grid;gap:8px}.quiz-stat-line{display:flex;align-items:center;justify-content:space-between;color:#d9e3ff;background:#0f172a80;border:1px solid rgba(148,163,184,.22);border-radius:10px;padding:10px 12px}.quiz-stat-line strong{color:#f8fafc}.quiz-question{display:flex;flex-direction:column;gap:12px}.quiz-state-chip{align-self:flex-start;font-size:.72rem;font-weight:800;letter-spacing:.12em;color:#7dd3fc;border:1px solid rgba(125,211,252,.55);background:#08192ecc;border-radius:999px;padding:5px 10px}.quiz-state-main-text{margin:0;font-size:clamp(1rem,2.8vw,1.25rem);font-weight:700;color:#e0f2fe}.quiz-state-wait-reveal{position:relative;border:1px solid rgba(125,211,252,.45);border-radius:16px;padding:14px;background:radial-gradient(circle at 20% 20%,#0e749047,#08101fbf);overflow:hidden;animation:wait-reveal-in .35s ease,wait-reveal-glow 1.8s ease-in-out infinite}.quiz-state-wait-reveal:after{content:"";position:absolute;inset:auto -25% -60% auto;width:240px;height:240px;border-radius:999px;background:radial-gradient(circle,rgba(56,189,248,.2),transparent 65%);pointer-events:none}.quiz-state-revealed{border:1px solid rgba(167,139,250,.48);border-radius:16px;padding:14px;background:linear-gradient(120deg,#2c124a8c,#1e293bb3);box-shadow:0 14px 30px #5b21b633;animation:reveal-card-in .45s ease}.quiz-state-chip-reveal{color:#e9d5ff;border-color:#d8b4fe9e;background:#3b0764a6}.quiz-reveal-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.quiz-reveal-item{background:#0f172a85;border:1px solid rgba(196,181,253,.32);border-radius:12px;padding:10px 12px;display:grid;gap:6px}.quiz-reveal-item strong{font-size:1.2rem;color:#f5f3ff;letter-spacing:.02em}.quiz-question-title{font-size:1rem;color:#d7e1ff;font-weight:700;letter-spacing:.03em}.quiz-timer{width:100%;height:8px;border-radius:999px;background:#94a3b84d;overflow:hidden;position:relative}.quiz-timer:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;width:var(--quiz-time-progress, 0%);background:linear-gradient(90deg,#3b82f6,#a855f7);transition:width .18s linear}.quiz-countdown-state{display:flex;flex-direction:column;align-items:center;gap:10px;min-height:130px;justify-content:center}.quiz-countdown-number{display:inline-flex;align-items:center;justify-content:center;width:110px;height:110px;border-radius:999px;font-size:3rem;color:#cffafe;font-weight:900;background:radial-gradient(circle,#38bdf86b,#0ea5e91f);border:3px solid rgba(147,197,253,.65);box-shadow:0 0 0 8px #38bdf81f;animation:countdown-pop .35s ease}.quiz-countdown-number--big{width:150px;height:150px;font-size:4rem;margin:0 auto}.quiz-countdown-ring{width:160px;height:160px;border-radius:999px;border:4px dashed rgba(186,230,253,.6);animation:countdown-spin 1.2s linear infinite}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-option{border:1px solid rgba(148,163,184,.38);background:#080e1ccc;color:#ecf2ff;border-radius:12px;padding:10px 12px;text-align:left;cursor:pointer;display:flex;gap:12px;align-items:center;justify-content:flex-start;transition:transform .15s ease,border-color .2s ease,background .2s ease,color .2s ease;font-size:1rem;min-height:58px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.quiz-options-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.quiz-option.selected{background:linear-gradient(120deg,#4ade8033,#10b98133);border-color:#4ade80;color:#f0fdf4;box-shadow:0 0 0 2px #4ade8038,0 10px 24px #16a34a2e}.quiz-option.locked{cursor:not-allowed}.quiz-option.muted,.quiz-option.muted:disabled{background:#15203894;border-color:#64748b57;color:#cbd5e1a3;box-shadow:none;opacity:.6}.quiz-option:active:not(:disabled){transform:scale(.985);border-color:#86efac;background:#22c55e29}.quiz-option.selected .quiz-option-index{border-color:#4ade80;color:#bef264;background:#14532db3}.quiz-option:disabled{cursor:not-allowed;opacity:.72}.quiz-option.selected:disabled{opacity:1}.quiz-state-answer-locked{margin-top:8px}.quiz-answer-locked-choice{display:grid;gap:6px;margin-top:8px;padding:12px 14px;border-radius:14px;border:1px solid rgba(74,222,128,.35);background:linear-gradient(135deg,#14532d73,#0f172ab8)}.quiz-answer-locked-choice strong{color:#f0fdf4;font-size:1.08rem}.quiz-option-index{width:26px;height:26px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;border:1px solid rgba(148,163,184,.45);color:#dbe7ff}@media (hover: hover) and (pointer: fine){.quiz-option:hover:not(:disabled){transform:translate(2px);border-color:#60a5fa;background:#38bdf81f}}.quiz-wait{padding:18px;border:1px dashed rgba(129,140,248,.5);border-radius:10px;color:#b8c9ec;text-align:center;background:#0f172a66;animation:pulse-wave 1.6s infinite}.quiz-leaderboard-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#11182799;border:1px solid rgba(148,163,184,.3);border-radius:10px;position:relative}.quiz-leaderboard-item.is-me{border-color:#60a5fa;box-shadow:inset 0 0 0 1px #60a5fa73;background:linear-gradient(90deg,#3b82f629,#0f172ab3)}.quiz-rank{color:#38bdf8;font-weight:800;min-width:26px;display:inline-block}.quiz-score{color:#eaf2ff;font-weight:700}.quiz-name{margin-left:6px}.quiz-phase{color:#dbeafe;text-transform:uppercase;font-weight:700;font-size:.82rem;letter-spacing:.06em}.quiz-finish{display:flex;flex-direction:column;gap:6px}.quiz-podium-kicker{margin:0;font-size:.88rem;letter-spacing:.2em;text-transform:uppercase;color:#7dd3fc;font-weight:800}.quiz-podium{margin-top:14px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;align-items:end}.quiz-podium-screen{max-width:980px;margin:16px auto 0}.quiz-podium-card{border-radius:16px;border:1px solid rgba(148,163,184,.4);background:linear-gradient(160deg,#081024e6,#1e293bb8);box-shadow:0 14px 30px #02061773;padding:14px 10px;text-align:center;animation:podium-rise .5s ease both;animation-delay:var(--podium-delay, 0ms)}.quiz-podium-card.rank-1{transform:translateY(-8px) scale(1.05);border-color:#fbbf24cc;background:linear-gradient(160deg,#78350f94,#1e293bb8)}.quiz-podium-card.rank-2{border-color:#7dd3fca6}.quiz-podium-card.rank-3{border-color:#fdba748c}.quiz-podium-rank{margin:0 0 8px;font-size:1.3rem;font-weight:900;color:#fef3c7}.quiz-podium-name{margin:0;font-size:1.12rem;font-weight:800;color:#f8fafc}.quiz-podium-score{margin:8px 0 0;font-size:1.06rem;font-weight:700;color:#93c5fd}.quiz-ready-pulse{display:inline-flex;width:9px;height:9px;border-radius:999px;background:#22c55e;animation:pulse-green 1.2s infinite}.quiz-wait .quiz-ready-pulse{margin-right:6px}.quiz-player-screen .quiz-card{animation:lift-in .45s ease}.quiz-host-screen .quiz-card{animation:rise-in .45s ease}.quiz-phase-question .quiz-hero{box-shadow:0 18px 36px #60a5fa4d,inset 0 0 0 1px #60a5fa4d}.quiz-phase-revealed .quiz-hero{box-shadow:0 18px 36px #a78bfa4d,inset 0 0 0 1px #a78bfa4d}.quiz-phase-finished .quiz-hero{box-shadow:0 18px 36px #22c55e47,inset 0 0 0 1px #22c55e59}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes rise-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes lift-in{0%{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes podium-rise{0%{transform:translateY(22px) scale(.92);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes pop-in{0%{opacity:0;transform:scale(.96)}80%{opacity:1;transform:scale(1.01)}to{opacity:1;transform:scale(1)}}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:.85}50%{transform:scale(1.8);opacity:.25}}@keyframes pulse-wave{0%{box-shadow:0 0 #38bdf821}70%{box-shadow:0 0 0 12px #38bdf800}to{box-shadow:0 0 #38bdf800}}@keyframes countdown-pop{0%{transform:scale(.84);opacity:.55}40%{transform:scale(1.08);opacity:1}to{transform:scale(1)}}@keyframes countdown-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse-green{0%,to{transform:scale(.9);opacity:.7}50%{transform:scale(1.4);opacity:1}}@keyframes top5-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes top5-item-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes top5-new-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes wait-reveal-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes wait-reveal-glow{0%,to{box-shadow:0 0 #38bdf81f}50%{box-shadow:0 0 0 10px #38bdf800}}@keyframes reveal-card-in{0%{opacity:0;transform:translateY(8px);filter:saturate(.7)}to{opacity:1;transform:translateY(0);filter:saturate(1)}}@media (max-width: 980px){.quiz-host-layout,.quiz-player-layout,.quiz-scoreboard,.quiz-screen-layout{grid-template-columns:1fr}.quiz-screen{gap:10px}.quiz-game-tool{padding:12px}.quiz-meta-grid{grid-template-columns:1fr}.quiz-game-tool:before,.quiz-game-tool:after{display:none}.quiz-options-grid,.quiz-reveal-grid{grid-template-columns:1fr}.quiz-podium{grid-template-columns:1fr;align-items:stretch}.quiz-podium-card.rank-1{transform:none}}@media (max-width: 620px){.quiz-top-band{gap:6px}.quiz-status-badge{font-size:.74rem;padding:5px 9px}.quiz-question-title{font-size:.95rem}.quiz-hero h2{font-size:1.05rem}}.about-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}.about-hero{position:relative;padding:72px 24px 40px;overflow:hidden}.about-hero:before,.about-hero:after{content:"";position:absolute;border-radius:50%;pointer-events:none}.about-hero:before{width:420px;height:420px;top:-140px;right:-120px;background:radial-gradient(circle at 30% 30%,rgba(33,150,243,.25),transparent 70%)}.about-hero:after{width:360px;height:360px;bottom:-180px;left:-120px;background:radial-gradient(circle at 40% 40%,rgba(33,150,243,.18),transparent 70%)}html.dark-mode .about-hero:before{background:radial-gradient(circle at 30% 30%,rgba(66,165,245,.3),transparent 70%)}html.dark-mode .about-hero:after{background:radial-gradient(circle at 40% 40%,rgba(66,165,245,.22),transparent 70%)}.about-hero-inner{position:relative;z-index:1;max-width:1100px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:40px;align-items:start}.about-eyebrow{display:inline-block;font-size:.9rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--accent-color);margin-bottom:12px}.about-title{font-size:clamp(2.2rem,2.6vw,3rem);margin:0 0 16px;line-height:1.2}.about-intro{font-size:1.05rem;line-height:1.7;color:var(--text-secondary);margin:0 0 18px}.about-quote{margin:0;padding:14px 18px;border-left:3px solid var(--accent-color);background:#2196f314;border-radius:8px;font-weight:600;color:var(--text-primary)}html.dark-mode .about-quote{background:#42a5f51f}.about-hero-card{background:linear-gradient(145deg,rgba(33,150,243,.08),var(--bg-secondary));border:1px solid var(--border-color);border-radius:20px;padding:24px;box-shadow:var(--shadow-md);display:grid;gap:18px}.about-card-section h3{margin:0 0 12px;font-size:1.05rem}.about-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}.about-list li{display:flex;gap:10px;align-items:flex-start;color:var(--text-secondary);font-size:.98rem;line-height:1.5}.about-list li:before{content:"";width:8px;height:8px;margin-top:6px;border-radius:50%;background:var(--accent-color);flex-shrink:0}.about-card-divider{height:1px;background:var(--border-color)}.about-grid{max-width:1100px;margin:0 auto;padding:10px 24px 24px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}.about-card{border-radius:18px;padding:28px;border:1px solid var(--border-color);background:var(--bg-secondary);box-shadow:var(--shadow-sm)}.about-card h2{margin:0 0 12px;font-size:1.3rem}.about-card p{margin:0;color:var(--text-secondary);line-height:1.7;font-size:1rem}.about-contact{padding:24px 24px 80px}.about-contact-card{max-width:1100px;margin:0 auto;border-radius:20px;padding:28px 32px;background:linear-gradient(120deg,#2196f31f,#2196f30a);border:1px solid rgba(33,150,243,.2);display:flex;align-items:center;justify-content:space-between;gap:20px}html.dark-mode .about-contact-card{background:linear-gradient(120deg,#42a5f533,#42a5f50d);border-color:#42a5f559}.about-contact-text h2{margin:0 0 8px;font-size:1.3rem}.about-contact-text p{margin:0;color:var(--text-secondary)}.about-contact-link{color:var(--accent-color);font-weight:700;text-decoration:none}.about-contact-link:hover{text-decoration:underline}.about-contact-button{display:inline-flex;align-items:center;justify-content:center;padding:12px 22px;border-radius:999px;background:var(--accent-color);color:#fff;text-decoration:none;font-weight:600;box-shadow:var(--shadow-sm);transition:transform .2s ease,background .2s ease,box-shadow .2s ease;white-space:nowrap}.about-contact-button:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media (max-width: 960px){.about-hero-inner,.about-grid{grid-template-columns:1fr}}@media (max-width: 720px){.about-hero{padding-top:56px}.about-contact-card{flex-direction:column;align-items:flex-start}}.form-builder-tool{max-width:960px;margin:0 auto;padding:24px 16px}.form-builder-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;gap:16px;flex-wrap:wrap}.form-builder-header h1{font-size:1.75rem;font-weight:700;margin:0}.form-builder-subtitle{color:var(--text-secondary, #666);margin:4px 0 0;font-size:.95rem}.form-builder-create-btn{padding:10px 24px;background:var(--color-primary, #4F46E5);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.form-builder-create-btn:hover{background:var(--color-primary-dark, #4338CA)}.form-builder-section-title{font-size:1.1rem;font-weight:600;margin-bottom:16px;color:var(--text-primary, #333)}.form-builder-loading{text-align:center;padding:48px;color:var(--text-secondary, #666)}.form-builder-empty{text-align:center;padding:64px 16px;color:var(--text-secondary, #666)}.form-builder-empty-icon{font-size:3rem;margin-bottom:16px}.form-builder-empty-hint{font-size:.875rem;margin-top:8px;opacity:.7}.form-builder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.form-card{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;padding:20px;transition:box-shadow .2s}.form-card:hover{box-shadow:0 4px 12px #00000014}.form-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}.form-card-title{font-size:1.05rem;font-weight:600;margin:0;line-height:1.4}.form-card-status{font-size:.75rem;padding:2px 8px;border-radius:12px;font-weight:500;white-space:nowrap;flex-shrink:0}.status-draft{background:#f3f4f6;color:#6b7280}.status-published{background:#dcfce7;color:#16a34a}.status-closed{background:#fee2e2;color:#dc2626}.form-card-desc{font-size:.875rem;color:var(--text-secondary, #666);margin:0 0 12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-card-meta{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-tertiary, #999);margin-bottom:12px}.form-card-actions{display:flex;gap:8px;flex-wrap:wrap}.form-card-actions button{padding:6px 12px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;background:transparent;font-size:.8rem;cursor:pointer;transition:all .2s;color:var(--text-primary, #333)}.form-card-actions button:hover{background:var(--bg-hover, #f9fafb)}.form-card-actions button.danger{color:#dc2626;border-color:#fecaca}.form-card-actions button.danger:hover{background:#fee2e2}@media (max-width: 640px){.form-builder-header{flex-direction:column}.form-builder-create-btn{width:100%}.form-builder-grid{grid-template-columns:1fr}}.form-editor{max-width:1400px;margin:0 auto;padding:0 16px 24px}.form-editor-loading,.form-editor-not-found{text-align:center;padding:64px 16px;color:var(--text-secondary, #666)}.form-editor-not-found button{margin-top:16px;padding:8px 16px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;background:transparent;cursor:pointer}.form-editor-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 0;margin-bottom:16px;border-bottom:1px solid var(--border-color, #e5e7eb);gap:12px;flex-wrap:wrap}.form-editor-back{background:none;border:none;color:var(--color-primary, #4F46E5);cursor:pointer;font-size:.9rem;padding:4px 0}.form-editor-toolbar-actions{display:flex;align-items:center;gap:8px}.form-editor-save-status{font-size:.8rem;color:var(--text-secondary, #666)}.btn-outline{padding:8px 16px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;background:transparent;cursor:pointer;font-size:.875rem;transition:all .2s;color:var(--text-primary, #333)}.btn-outline:hover{background:var(--bg-hover, #f9fafb)}.btn-primary{padding:8px 16px;border:none;border-radius:6px;background:var(--color-primary, #4F46E5);color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:var(--color-primary-dark, #4338CA)}.form-editor-layout{display:grid;grid-template-columns:60% 40%;gap:24px;min-height:calc(100vh - 200px)}.form-editor-section-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #888);margin-bottom:12px;font-weight:600}.form-editor-left{overflow-y:auto}.form-editor-title-area{margin-bottom:20px}.form-editor-title-input{width:100%;font-size:1.5rem;font-weight:700;border:none;border-bottom:2px solid var(--border-color, #e5e7eb);padding:8px 0;outline:none;background:transparent;color:var(--text-primary, #333)}.form-editor-title-input:focus{border-bottom-color:var(--color-primary, #4F46E5)}.form-editor-desc-input{width:100%;border:none;border-bottom:1px solid var(--border-color, #e5e7eb);padding:8px 0;outline:none;resize:none;font-size:.95rem;background:transparent;color:var(--text-secondary, #666)}.form-editor-desc-input:focus{border-bottom-color:var(--color-primary, #4F46E5)}.form-editor-fields{margin-bottom:20px}.form-editor-no-fields{text-align:center;padding:32px;color:var(--text-secondary, #999);border:2px dashed var(--border-color, #e5e7eb);border-radius:12px}.form-field-card{border:1px solid var(--border-color, #e5e7eb);border-radius:8px;margin-bottom:8px;background:var(--bg-card, #fff);transition:border-color .2s}.form-field-card.editing{border-color:var(--color-primary, #4F46E5)}.form-field-card-header{display:flex;align-items:center;padding:12px 16px;cursor:pointer;gap:8px}.form-field-card-drag{color:var(--text-tertiary, #bbb);cursor:grab;font-size:1.1rem}.form-field-card-icon{font-size:1rem}.form-field-card-label{flex:1;font-weight:500;font-size:.95rem}.form-field-required{color:#dc2626;font-weight:700}.form-field-card-actions{display:flex;gap:4px}.form-field-card-actions button{background:none;border:none;cursor:pointer;padding:2px 6px;font-size:.8rem;color:var(--text-secondary, #888);border-radius:4px}.form-field-card-actions button:hover{background:var(--bg-hover, #f3f4f6)}.form-field-card-actions button.danger:hover{background:#fee2e2;color:#dc2626}.form-field-edit-panel{padding:0 16px 16px;border-top:1px solid var(--border-color, #f3f4f6)}.form-field-edit-row{margin-top:12px}.form-field-edit-row label{display:block;font-size:.8rem;color:var(--text-secondary, #666);margin-bottom:4px}.form-field-edit-row input[type=text],.form-field-edit-row input[type=number]{width:100%;padding:8px 12px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:.9rem;outline:none;background:var(--bg-input, #fff);color:var(--text-primary, #333)}.form-field-edit-row input:focus{border-color:var(--color-primary, #4F46E5)}.form-field-edit-row.checkbox-row label{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer}.form-field-options{margin-top:12px}.form-field-option-row{display:flex;gap:8px;margin-bottom:6px;align-items:center}.form-field-option-row input{flex:1;padding:6px 10px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:.85rem;outline:none;background:var(--bg-input, #fff);color:var(--text-primary, #333)}.option-delete{background:none;border:none;cursor:pointer;color:var(--text-secondary, #999);font-size:.9rem;padding:4px}.option-delete:hover{color:#dc2626}.option-add{background:none;border:1px dashed var(--border-color, #d1d5db);border-radius:6px;padding:6px 12px;cursor:pointer;font-size:.85rem;color:var(--color-primary, #4F46E5);width:100%;margin-top:4px}.option-add:hover{background:var(--bg-hover, #f9fafb)}.form-editor-add-field{margin-top:8px}.form-editor-add-label{font-size:.85rem;font-weight:600;margin-bottom:8px;color:var(--text-secondary, #666)}.form-editor-add-buttons{display:flex;flex-wrap:wrap;gap:8px}.form-editor-add-buttons button{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;background:var(--bg-card, #fff);cursor:pointer;font-size:.85rem;transition:all .2s;color:var(--text-primary, #333)}.form-editor-add-buttons button:hover{border-color:var(--color-primary, #4F46E5);background:var(--bg-hover, #f5f3ff)}.form-editor-right{position:sticky;top:80px;align-self:start}.form-preview-container{background:var(--bg-secondary, #f9fafb);border-radius:12px;padding:24px;display:flex;justify-content:center}.form-preview-card{width:100%;max-width:480px;background:var(--bg-card, #fff);border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.form-preview-title{font-size:1.25rem;font-weight:700;margin:0 0 8px}.form-preview-desc{font-size:.9rem;color:var(--text-secondary, #666);margin:0 0 20px}.form-preview-fields{display:flex;flex-direction:column;gap:20px}.form-preview-field{display:flex;flex-direction:column}.form-preview-label{font-size:.9rem;font-weight:600;margin-bottom:6px;color:var(--text-primary, #333)}.form-preview-label .required-mark{color:#dc2626}.form-preview-field-desc{font-size:.8rem;color:var(--text-secondary, #999);margin:0 0 6px}.form-preview-field input[type=text],.form-preview-field input[type=date],.form-preview-field textarea,.form-preview-field select{padding:8px 12px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:.9rem;background:var(--bg-input, #fff);color:var(--text-primary, #333)}.form-preview-options{display:flex;flex-direction:column;gap:8px}.form-preview-radio,.form-preview-checkbox{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:default}.form-preview-rating{display:flex;gap:4px}.form-preview-rating .star{font-size:1.5rem;color:#d4d4d8}.form-preview-submit{margin-top:24px;width:100%;padding:12px;background:var(--color-primary, #4F46E5);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:not-allowed;opacity:.7}.form-editor-toolbar-left{display:flex;align-items:center;gap:12px}.form-editor-status-badge{font-size:.75rem;padding:2px 10px;border-radius:12px;font-weight:500;white-space:nowrap}.btn-danger-outline{color:#dc2626!important;border-color:#fecaca!important}.btn-danger-outline:hover{background:#fee2e2!important}.form-field-edit-row-inline{display:flex;gap:12px;margin-top:12px}.form-field-edit-row-inline .form-field-edit-row{flex:1;margin-top:0}.form-field-options-label{display:block;font-size:.8rem;color:var(--text-secondary, #666);margin-bottom:8px;font-weight:600}.form-field-card.dragging-overlay{box-shadow:0 8px 24px #00000026;border-color:var(--color-primary, #4F46E5);background:var(--bg-card, #fff);cursor:grabbing}.form-editor-preview-toggle{display:none;width:100%;margin-top:16px;text-align:center}.form-editor-preview-mode{display:inline-flex;gap:4px;margin-left:12px}.form-editor-preview-mode button{padding:4px 12px;border:1px solid var(--border-color, #e5e7eb);border-radius:4px;background:transparent;cursor:pointer;font-size:.75rem;color:var(--text-secondary, #666)}.form-editor-preview-mode button.active{background:var(--color-primary, #4F46E5);color:#fff;border-color:var(--color-primary, #4F46E5)}.form-settings-panel{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;margin-bottom:20px;overflow:hidden}.form-settings-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border-color, #f3f4f6)}.form-settings-header h3{margin:0;font-size:1rem}.form-settings-close{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-secondary, #999);padding:4px 8px;border-radius:4px}.form-settings-close:hover{background:var(--bg-hover, #f3f4f6)}.form-settings-body{padding:16px 20px;display:flex;flex-direction:column;gap:16px}.form-settings-row label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary, #555);margin-bottom:6px}.form-settings-row input[type=text],.form-settings-row input[type=password],.form-settings-row input[type=number],.form-settings-row input[type=datetime-local],.form-settings-row textarea{width:100%;padding:8px 12px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:.9rem;outline:none;background:var(--bg-input, #fff);color:var(--text-primary, #333)}.form-settings-row input:focus,.form-settings-row textarea:focus{border-color:var(--color-primary, #4F46E5)}.form-settings-row textarea{resize:vertical}.form-settings-colors{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.color-swatch{width:32px;height:32px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:border-color .2s,transform .15s}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{border-color:var(--text-primary, #333)}.form-settings-custom-color{display:flex;gap:8px;align-items:center}.form-settings-custom-color input{max-width:120px}.color-preview{width:28px;height:28px;border-radius:6px;border:1px solid var(--border-color, #e5e7eb);flex-shrink:0}.form-settings-row.toggle-row label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem}.form-settings-row.indent{margin-left:24px}.form-settings-hint{display:block;font-size:.75rem;color:var(--text-tertiary, #999);margin-top:4px}.share-dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.share-dialog{background:var(--bg-card, #fff);border-radius:16px;width:100%;max-width:480px;box-shadow:0 16px 48px #0003;overflow:hidden}.share-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color, #f3f4f6)}.share-dialog-header h3{margin:0;font-size:1.1rem}.share-dialog-close{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-secondary, #999);padding:4px 8px;border-radius:4px}.share-dialog-close:hover{background:var(--bg-hover, #f3f4f6)}.share-dialog-body{padding:20px}.share-dialog-label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary, #666);margin-bottom:8px}.share-dialog-link-row{display:flex;gap:8px;margin-bottom:20px}.share-dialog-link-row input{flex:1;padding:8px 12px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:.85rem;background:var(--bg-secondary, #f9fafb);color:var(--text-primary, #333);outline:none}.share-dialog-copy{padding:8px 16px;background:var(--color-primary, #4F46E5);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;white-space:nowrap;transition:background .2s}.share-dialog-copy:hover{background:var(--color-primary-dark, #4338CA)}.share-dialog-qr{text-align:center}.share-dialog-qr img{width:200px;height:200px;margin:8px 0 12px;border-radius:8px}.share-dialog-download-qr{padding:8px 16px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;background:transparent;cursor:pointer;font-size:.85rem;color:var(--text-primary, #333)}.share-dialog-download-qr:hover{background:var(--bg-hover, #f9fafb)}@media (max-width: 1024px){.form-editor-layout{grid-template-columns:1fr}.form-editor-right{position:static}.form-editor-preview-toggle{display:block}}@media (max-width: 640px){.form-editor-toolbar{flex-direction:column;align-items:flex-start}.form-editor-toolbar-actions{width:100%;justify-content:flex-end}}.form-fill{max-width:640px;margin:0 auto;padding:24px 16px}.form-fill-message{text-align:center;padding:64px 16px;color:var(--text-secondary, #666);font-size:1.1rem}.form-fill-password{display:flex;justify-content:center;padding:64px 16px}.form-fill-password-card{background:var(--bg-card, #fff);padding:32px;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center;max-width:400px;width:100%}.form-fill-password-card h2{margin:0 0 8px;font-size:1.25rem}.form-fill-password-card p{color:var(--text-secondary, #666);margin-bottom:16px}.form-fill-password-card input{width:100%;padding:10px 14px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:1rem;margin-bottom:12px;outline:none}.form-fill-password-card button{width:100%;padding:10px;background:var(--color-primary, #4F46E5);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer}.form-fill-error{color:#dc2626;font-size:.85rem;margin-bottom:8px}.form-fill-thankyou{display:flex;justify-content:center;padding:64px 16px}.form-fill-thankyou-card{text-align:center;max-width:400px}.form-fill-thankyou-icon{font-size:3rem;margin-bottom:16px}.form-fill-thankyou-card p{font-size:1.1rem;margin-bottom:24px;color:var(--text-primary, #333)}.form-fill-thankyou-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.form-fill-thankyou-actions button,.form-fill-thankyou-actions a{padding:10px 20px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;background:transparent;cursor:pointer;font-size:.9rem;text-decoration:none;color:var(--text-primary, #333)}.form-fill-thankyou-actions button:hover,.form-fill-thankyou-actions a:hover{background:var(--bg-hover, #f9fafb)}.form-fill-card{background:var(--bg-card, #fff);border-radius:12px;box-shadow:0 1px 4px #00000014;overflow:hidden}.form-fill-header{padding:24px 24px 16px;border-top:4px solid var(--color-primary, #4F46E5)}.form-fill-header h1{font-size:1.5rem;margin:0 0 8px}.form-fill-header p{color:var(--text-secondary, #666);margin:0;font-size:.95rem}.form-fill-field{padding:16px 24px;border-top:1px solid var(--border-color, #f3f4f6)}.form-fill-label{display:block;font-size:.95rem;font-weight:600;margin-bottom:8px;color:var(--text-primary, #333)}.required-mark{color:#dc2626}.form-fill-field-desc{font-size:.8rem;color:var(--text-secondary, #999);margin:-4px 0 8px}.form-fill-field input[type=text],.form-fill-field input[type=email],.form-fill-field input[type=date],.form-fill-field textarea,.form-fill-field select{width:100%;padding:10px 14px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:.95rem;outline:none;background:var(--bg-input, #fff);color:var(--text-primary, #333);transition:border-color .2s}.form-fill-field input:focus,.form-fill-field textarea:focus,.form-fill-field select:focus{border-color:var(--color-primary, #4F46E5)}.form-fill-field .has-error{border-color:#dc2626}.form-fill-field-error{color:#dc2626;font-size:.8rem;margin:4px 0 0}.form-fill-options{display:flex;flex-direction:column;gap:10px}.form-fill-radio,.form-fill-checkbox{display:flex;align-items:center;gap:10px;font-size:.95rem;cursor:pointer}.form-fill-rating{display:flex;gap:4px}.form-fill-rating .star{font-size:1.75rem;color:#d4d4d8;transition:color .15s}.form-fill-rating .star.filled,.form-fill-rating .star:hover{color:#f59e0b}.form-fill-submit{display:block;width:calc(100% - 48px);margin:16px 24px 24px;padding:12px;background:var(--color-primary, #4F46E5);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.form-fill-submit:hover{opacity:.9}.form-fill-submit:disabled{opacity:.6;cursor:not-allowed}.form-fill-error-icon,.form-fill-password-icon{font-size:3rem;margin-bottom:16px}.field-input-wrapper{position:relative}.field-input-wrapper input,.field-input-wrapper textarea{width:100%;padding:10px 14px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:.95rem;outline:none;background:var(--bg-input, #fff);color:var(--text-primary, #333);transition:border-color .2s}.field-input-wrapper input:focus,.field-input-wrapper textarea:focus{border-color:var(--color-primary, #4F46E5)}.field-input-wrapper .has-error{border-color:#dc2626}.field-char-count{position:absolute;right:10px;bottom:8px;font-size:.7rem;color:var(--text-tertiary, #bbb);pointer-events:none}.field-hint{font-size:.75rem;color:var(--text-tertiary, #999);margin-top:4px}@media (max-width: 640px){.form-fill{padding:12px 8px}.form-fill-header{padding:20px 16px 12px}.form-fill-field{padding:14px 16px}.form-fill-submit{width:calc(100% - 32px);margin:16px 16px 20px}}.form-results{max-width:1100px;margin:0 auto;padding:24px 16px}.form-results-message{text-align:center;padding:64px 16px;color:var(--text-secondary, #666)}.form-results-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;gap:16px;flex-wrap:wrap}.form-results-back{background:none;border:none;color:var(--color-primary, #4F46E5);cursor:pointer;font-size:.85rem;padding:0;margin-bottom:8px}.form-results-header h1{font-size:1.5rem;margin:0}.form-results-count{font-size:.9rem;color:var(--text-secondary, #666)}.form-results-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.form-results-actions button,.form-results-actions a{padding:8px 14px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;background:var(--bg-card, #fff);cursor:pointer;font-size:.85rem;text-decoration:none;color:var(--text-primary, #333);transition:all .2s}.form-results-actions button:hover,.form-results-actions a:hover{background:var(--bg-hover, #f9fafb)}.form-results-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color, #e5e7eb);margin-bottom:20px}.form-results-tabs button{padding:10px 20px;border:none;background:none;cursor:pointer;font-size:.95rem;font-weight:500;color:var(--text-secondary, #666);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.form-results-tabs button.active{color:var(--color-primary, #4F46E5);border-bottom-color:var(--color-primary, #4F46E5)}.form-results-tabs button:hover{color:var(--text-primary, #333)}.form-results-empty{text-align:center;padding:48px;color:var(--text-secondary, #999)}.form-results-empty-icon{font-size:3rem;margin-bottom:16px}.form-results-empty-hint{font-size:.85rem;margin-top:8px;opacity:.7}.form-results-table-wrapper{overflow-x:auto}.form-results-table{width:100%;border-collapse:collapse;font-size:.85rem}.form-results-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border-color, #e5e7eb);font-weight:600;white-space:nowrap;color:var(--text-primary, #333);background:var(--bg-secondary, #f9fafb)}.form-results-table td{padding:10px 12px;border-bottom:1px solid var(--border-color, #f3f4f6);color:var(--text-primary, #333)}.form-results-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-results-date{white-space:nowrap;font-size:.8rem;color:var(--text-secondary, #999)}.form-results-delete{background:none;border:none;color:#dc2626;cursor:pointer;font-size:.8rem;padding:4px 8px;border-radius:4px}.form-results-delete:hover{background:#fee2e2}.form-results-pagination{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:16px}.form-results-pagination button{padding:6px 14px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;background:transparent;cursor:pointer;font-size:.85rem;color:var(--text-primary, #333)}.form-results-pagination button:disabled{opacity:.4;cursor:not-allowed}.form-results-pagination span{font-size:.85rem;color:var(--text-secondary, #666)}.form-results-stats{display:flex;flex-direction:column;gap:20px}.form-stat-card{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;padding:20px}.form-stat-card h3{font-size:1rem;margin:0 0 8px}.form-stat-meta{display:flex;gap:16px;font-size:.8rem;color:var(--text-secondary, #999);margin-bottom:16px}.form-stat-bars{display:flex;flex-direction:column;gap:8px}.form-stat-bar-row{display:flex;align-items:center;gap:12px}.form-stat-bar-label{width:120px;font-size:.85rem;text-align:right;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-stat-bar-track{flex:1;height:24px;background:var(--bg-secondary, #f3f4f6);border-radius:6px;overflow:hidden}.form-stat-bar-fill{height:100%;background:var(--color-primary, #4F46E5);border-radius:6px;min-width:2px;transition:width .3s ease}.form-stat-bar-value{font-size:.8rem;color:var(--text-secondary, #666);white-space:nowrap;width:80px}.form-stat-recent h4{font-size:.85rem;margin:0 0 8px;color:var(--text-secondary, #666)}.form-stat-recent ul{list-style:none;padding:0;margin:0}.form-stat-recent li{padding:6px 12px;border-bottom:1px solid var(--border-color, #f3f4f6);font-size:.85rem;color:var(--text-primary, #333)}@media (max-width: 768px){.form-results-header{flex-direction:column}.form-stat-bar-label{width:80px;font-size:.75rem}.form-stat-bar-value{width:60px;font-size:.75rem}}.snake-game-container{max-width:520px;margin:0 auto;padding:20px 16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.snake-game-container h2{text-align:center;margin-bottom:16px;font-size:1.5rem}.snake-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.snake-scores{display:flex;gap:12px}.snake-score-box{background:var(--card-bg, #f0f0f0);border-radius:10px;padding:6px 16px;text-align:center;min-width:70px}.snake-score-box .label{font-size:.75rem;color:var(--text-secondary, #888);margin-bottom:2px}.snake-score-box .value{font-size:1.5rem;font-weight:700;color:var(--text-primary, #222)}.snake-restart-btn{display:flex;align-items:center;gap:6px;padding:8px 18px;border:2px solid #1a56db;border-radius:10px;background:transparent;color:#1a56db;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s}.snake-restart-btn:hover{background:#1a56db;color:#fff}.snake-board-wrapper{position:relative;background:var(--card-bg, #f0f0f0);border-radius:16px;padding:8px;margin-bottom:12px}.snake-canvas{display:block;width:100%;border-radius:10px;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.snake-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#00000073;border-radius:16px;color:#fff;z-index:2}.snake-overlay h3{font-size:1.6rem;margin-bottom:8px}.snake-overlay p{font-size:1rem;margin-bottom:16px;opacity:.85}.snake-overlay button{padding:10px 28px;border:none;border-radius:8px;background:#1a56db;color:#fff;font-size:1rem;font-weight:600;cursor:pointer}.snake-overlay button:hover{background:#1444b0}.snake-hint{text-align:center;color:var(--text-secondary, #999);font-size:.85rem;margin-top:4px}.snake-mobile-controls{display:none;justify-content:center;margin-top:12px}.snake-dpad{display:grid;grid-template-areas:". up ." "left . right" ". down .";gap:6px}.snake-dpad button{width:56px;height:56px;border:2px solid var(--border-color, #ccc);border-radius:12px;background:var(--card-bg, #f5f5f5);font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.snake-dpad button:active{background:#1a56db;color:#fff;border-color:#1a56db}.snake-dpad .up{grid-area:up}.snake-dpad .down{grid-area:down}.snake-dpad .left{grid-area:left}.snake-dpad .right{grid-area:right}@media (max-width: 600px){.snake-mobile-controls{display:flex}}:root.dark-mode .snake-score-box{background:#2a2a2a}:root.dark-mode .snake-score-box .value{color:#eee}:root.dark-mode .snake-board-wrapper{background:#2a2a2a}:root.dark-mode .snake-dpad button{background:#333;border-color:#555;color:#ccc}.stair-game-container{max-width:520px;margin:0 auto;padding:20px 16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.stair-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.stair-scores{display:flex;gap:12px}.stair-score-box{background:var(--card-bg, #f0f0f0);border-radius:10px;padding:6px 16px;text-align:center;min-width:70px}.stair-score-box .label{font-size:.75rem;color:var(--text-secondary, #888);margin-bottom:2px}.stair-score-box .value{font-size:1.5rem;font-weight:700;color:var(--text-primary, #222)}.stair-restart-btn{display:flex;align-items:center;gap:6px;padding:8px 18px;border:2px solid #1a56db;border-radius:10px;background:transparent;color:#1a56db;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s}.stair-restart-btn:hover{background:#1a56db;color:#fff}.stair-board-wrapper{position:relative;background:var(--card-bg, #f0f0f0);border-radius:16px;padding:8px;margin-bottom:12px}.stair-canvas{display:block;width:100%;border-radius:10px;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.stair-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#00000073;border-radius:16px;color:#fff;z-index:2}.stair-overlay h3{font-size:1.6rem;margin-bottom:8px}.stair-overlay p{font-size:1rem;margin-bottom:16px;opacity:.85}.stair-overlay button{padding:10px 28px;border:none;border-radius:8px;background:#1a56db;color:#fff;font-size:1rem;font-weight:600;cursor:pointer}.stair-overlay button:hover{background:#1444b0}.stair-hint{text-align:center;color:var(--text-secondary, #999);font-size:.85rem;margin-top:4px}.stair-mobile-controls{display:none;justify-content:center;gap:16px;margin-top:12px}.stair-mobile-controls button{width:72px;height:56px;border:2px solid var(--border-color, #ccc);border-radius:12px;background:var(--card-bg, #f5f5f5);font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.stair-mobile-controls button:active{background:#1a56db;color:#fff;border-color:#1a56db}@media (max-width: 600px){.stair-mobile-controls{display:flex}}.stair-new-record{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:12px}.stair-new-record-badge{background:#fbbf24;color:#222;font-weight:700;font-size:.85rem;padding:3px 12px;border-radius:20px}.stair-name-form{display:flex;gap:6px}.stair-name-input{padding:8px 12px;border:2px solid rgba(255,255,255,.4);border-radius:8px;background:#ffffff26;color:#fff;font-size:.95rem;width:140px;outline:none}.stair-name-input::placeholder{color:#ffffff80}.stair-name-input:focus{border-color:#fbbf24}.stair-submit-btn{padding:8px 16px!important;background:#fbbf24!important;color:#222!important;font-weight:700!important;border-radius:8px!important;margin-bottom:0!important}.stair-submit-btn:disabled{opacity:.5;cursor:not-allowed!important}.stair-submitted-msg{color:#fbbf24!important;font-weight:600;opacity:1!important}.stair-leaderboard{margin-top:20px;background:var(--card-bg, #f5f5f5);border-radius:14px;padding:16px}.stair-leaderboard h3{text-align:center;font-size:1.1rem;margin-bottom:12px;color:var(--text-primary, #222)}.stair-lb-empty{text-align:center;color:var(--text-secondary, #999);font-size:.9rem;padding:20px 0}.stair-lb-table{width:100%;border-collapse:collapse}.stair-lb-table th{font-size:.75rem;color:var(--text-secondary, #888);text-align:left;padding:4px 8px 8px;border-bottom:1px solid var(--border-color, #ddd)}.stair-lb-table th:last-child{text-align:right}.stair-lb-table td{padding:8px;font-size:.9rem;color:var(--text-primary, #333);border-bottom:1px solid var(--border-color, #eee)}.stair-lb-rank{width:36px;text-align:center}.stair-lb-name{font-weight:500}.stair-lb-score{text-align:right;font-weight:700;font-variant-numeric:tabular-nums}.stair-lb-top1 td{color:#d97706}.stair-lb-top2 td{color:#6b7280}.stair-lb-top3 td{color:#b45309}:root.dark-mode .stair-score-box{background:#2a2a2a}:root.dark-mode .stair-score-box .value{color:#eee}:root.dark-mode .stair-board-wrapper{background:#2a2a2a}:root.dark-mode .stair-mobile-controls button{background:#333;border-color:#555;color:#ccc}:root.dark-mode .stair-leaderboard{background:#2a2a2a}:root.dark-mode .stair-leaderboard h3{color:#eee}:root.dark-mode .stair-lb-table td{color:#ddd;border-bottom-color:#3a3a3a}:root.dark-mode .stair-lb-table th{border-bottom-color:#3a3a3a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);min-height:100vh}#root{min-height:100vh}
