@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-deep: #070d1a;--bg-base: #0d1425;--bg-surface: #111c33;--bg-elevated: #162040;--bg-hover: #1c2a50;--border: #1e2d50;--border-subtle: #162040;--accent: #4f6ef7;--accent-glow: rgba(79, 110, 247, .18);--accent-hover: #6681ff;--accent-light: rgba(79, 110, 247, .12);--text-primary: #e8edf5;--text-secondary: #8b9abd;--text-muted: #4e5f80;--text-accent: #7b9bff;--get: #10b981;--get-bg: rgba(16, 185, 129, .12);--post: #4f6ef7;--post-bg: rgba(79, 110, 247, .15);--put: #f59e0b;--put-bg: rgba(245, 158, 11, .12);--delete: #ef4444;--delete-bg: rgba(239, 68, 68, .12);--patch: #8b5cf6;--patch-bg: rgba(139, 92, 246, .12);--bearer-color: #f59e0b;--bearer-bg: rgba(245, 158, 11, .1);--admin-color: #e879f9;--admin-bg: rgba(232, 121, 249, .1);--sidebar-width: 280px;--topbar-height: 60px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 22px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 24px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-glow: 0 0 30px rgba(79, 110, 247, .12);--transition: all .2s ease;--transition-slow: all .35s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg-deep);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}h1,h2,h3,h4,h5{font-weight:600;color:var(--text-primary)}h1{font-size:2rem}h2{font-size:1.6rem}h3{font-size:1.25rem}h4{font-size:1rem}p{color:var(--text-secondary)}a{color:var(--text-accent);text-decoration:none;transition:var(--transition)}a:hover{color:var(--accent-hover)}code,pre{font-family:JetBrains Mono,Fira Code,monospace}.app-shell{display:flex;height:100vh;overflow:hidden}.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-height);background:#0d1425d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:100;box-shadow:var(--shadow-sm)}.topbar__logo{display:flex;align-items:center;gap:10px}.topbar__logo-icon{width:34px;height:34px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent),#7b5bf7);display:flex;align-items:center;justify-content:center;box-shadow:0 0 16px #4f6ef766}.topbar__logo-text{font-size:1.05rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.topbar__logo-text span{color:var(--text-accent)}.topbar__meta{display:flex;align-items:center;gap:16px}.topbar__version{font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);padding:3px 10px;border-radius:100px;letter-spacing:.3px;text-transform:uppercase}.topbar__api-base{font-size:.78rem;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);padding:4px 14px;border-radius:100px;font-family:JetBrains Mono,monospace}.sidebar{width:var(--sidebar-width);flex-shrink:0;height:100vh;padding-top:var(--topbar-height);overflow-y:auto;background:#0b1120eb;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50}.sidebar__search{padding:16px 16px 12px;position:relative}.sidebar__search-input{width:100%;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 12px 8px 36px;color:var(--text-primary);font-size:.82rem;font-family:Inter,sans-serif;transition:var(--transition);outline:none}.sidebar__search-input::placeholder{color:var(--text-muted)}.sidebar__search-input:focus{border-color:var(--accent);background:var(--bg-hover);box-shadow:0 0 0 3px var(--accent-light)}.sidebar__search-icon{position:absolute;left:28px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.sidebar__nav{flex:1;padding:0 10px 24px;display:flex;flex-direction:column;gap:2px}.sidebar__section{margin-bottom:6px}.sidebar__section-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:12px 10px 4px}.sidebar__item{display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:var(--radius-sm);font-size:.82rem;color:var(--text-secondary);cursor:pointer;transition:var(--transition);border:none;background:none;width:100%;text-align:left;-webkit-user-select:none;user-select:none}.sidebar__item:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar__item.active{background:var(--accent-light);color:var(--text-accent);font-weight:500}.sidebar__item-method{font-size:.62rem;font-weight:700;font-family:JetBrains Mono,monospace;padding:1px 5px;border-radius:3px;flex-shrink:0;min-width:40px;text-align:center}.sidebar__item-path{font-size:.76rem;font-family:JetBrains Mono,monospace;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.sidebar__no-results{text-align:center;padding:24px 12px;color:var(--text-muted);font-size:.82rem}.main-content{margin-left:var(--sidebar-width);padding-top:var(--topbar-height);flex:1;overflow-y:auto;min-height:100vh}.content-wrapper{max-width:900px;margin:0 auto;padding:40px 32px 80px}.api-docs-hero{margin-bottom:48px;padding:40px;background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-elevated) 100%);border:1px solid var(--border);border-radius:var(--radius-xl);position:relative;overflow:hidden}.api-docs-hero:before{content:"";position:absolute;top:-60px;right:-40px;width:300px;height:300px;background:radial-gradient(circle,rgba(79,110,247,.15) 0%,transparent 70%);pointer-events:none}.api-docs-hero__title{font-size:2rem;font-weight:700;margin-bottom:10px;background:linear-gradient(135deg,#e8edf5 0%,var(--text-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.api-docs-hero__subtitle{font-size:1rem;color:var(--text-secondary);margin-bottom:20px}.api-docs-hero__stats{display:flex;gap:24px;flex-wrap:wrap}.api-docs-hero__stat{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary)}.api-docs-hero__stat strong{color:var(--text-accent);font-size:1.1rem}.section-header{display:flex;align-items:center;gap:14px;margin:48px 0 20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.section-header__icon{width:38px;height:38px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.section-header__info{flex:1}.section-header__title{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin-bottom:2px}.section-header__desc{font-size:.82rem;color:var(--text-muted)}.section-header__count{font-size:.75rem;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);padding:3px 10px;border-radius:100px}.endpoint-card{border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:10px;overflow:hidden;transition:var(--transition);background:var(--bg-surface)}.endpoint-card:hover{border-color:var(--accent);box-shadow:var(--shadow-glow)}.endpoint-card.expanded{border-color:var(--accent)}.endpoint-card__header{display:flex;align-items:center;gap:12px;padding:13px 18px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:var(--transition)}.endpoint-card__header:hover{background:var(--bg-elevated)}.endpoint-card__path{font-family:JetBrains Mono,monospace;font-size:.84rem;color:var(--text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.endpoint-card__path .path-param{color:var(--accent-hover)}.endpoint-card__summary{font-size:.78rem;color:var(--text-muted);flex-shrink:0;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.endpoint-card__chevron{color:var(--text-muted);transition:transform .25s ease;flex-shrink:0}.endpoint-card.expanded .endpoint-card__chevron{transform:rotate(180deg)}.endpoint-card__body{border-top:1px solid var(--border);overflow:hidden;max-height:0;transition:max-height .35s cubic-bezier(.4,0,.2,1),opacity .25s ease;opacity:0}.endpoint-card.expanded .endpoint-card__body{max-height:2000px;opacity:1}.endpoint-card__body-inner{padding:20px;display:flex;flex-direction:column;gap:20px}.auth-badge{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:100px}.auth-badge.bearer{color:var(--bearer-color);background:var(--bearer-bg);border:1px solid rgba(245,158,11,.25)}.auth-badge.admin{color:var(--admin-color);background:var(--admin-bg);border:1px solid rgba(232,121,249,.25)}.auth-badge.public{color:var(--get);background:var(--get-bg);border:1px solid rgba(16,185,129,.25)}.params-section h4,.responses-section h4,.curl-section h4,.body-section h4{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px}.params-table{width:100%;border-collapse:collapse;font-size:.8rem}.params-table th{text-align:left;padding:8px 12px;background:var(--bg-elevated);color:var(--text-muted);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}.params-table th:first-child{border-radius:var(--radius-sm) 0 0 0}.params-table th:last-child{border-radius:0 var(--radius-sm) 0 0}.params-table td{padding:9px 12px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);vertical-align:top}.params-table tr:last-child td{border-bottom:none}.params-table td:first-child{font-family:JetBrains Mono,monospace;color:var(--text-accent);font-size:.78rem}.param-required{color:var(--delete);font-size:.68rem;font-weight:700;margin-left:4px}.param-type{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.72rem}.curl-block{position:relative;background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.curl-block pre{padding:16px;font-size:.78rem;line-height:1.7;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all}.curl-block pre .curl-flag{color:var(--text-accent)}.curl-block pre .curl-url{color:var(--get)}.curl-block pre .curl-header{color:var(--put)}.curl-block pre .curl-data{color:var(--text-primary)}.curl-copy-btn{position:absolute;top:8px;right:8px;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);padding:5px 10px;font-size:.72rem;font-family:Inter,sans-serif;cursor:pointer;display:flex;align-items:center;gap:5px;transition:var(--transition)}.curl-copy-btn:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--accent)}.curl-copy-btn.copied{color:var(--get);border-color:var(--get)}.response-codes{display:flex;flex-wrap:wrap;gap:8px}.response-code{display:flex;align-items:center;gap:6px;font-size:.76rem;padding:4px 12px;border-radius:100px;font-family:JetBrains Mono,monospace;font-weight:500}.response-code.success{background:var(--get-bg);color:var(--get);border:1px solid rgba(16,185,129,.2)}.response-code.created{background:var(--post-bg);color:var(--post);border:1px solid rgba(79,110,247,.2)}.response-code.no-content{background:#6366f11a;color:#818cf8;border:1px solid rgba(99,102,241,.2)}.response-code.bad-request{background:var(--delete-bg);color:var(--delete);border:1px solid rgba(239,68,68,.2)}.response-code.unauthorized{background:var(--put-bg);color:var(--put);border:1px solid rgba(245,158,11,.2)}.response-code.forbidden{background:var(--put-bg);color:#fb923c;border:1px solid rgba(251,146,60,.2)}.response-code.not-found{background:#9ca3af1a;color:#9ca3af;border:1px solid rgba(156,163,175,.2)}.response-code.conflict{background:var(--patch-bg);color:var(--patch);border:1px solid rgba(139,92,246,.2)}.method-badge{display:inline-flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;font-family:JetBrains Mono,monospace;padding:3px 8px;border-radius:5px;letter-spacing:.4px;flex-shrink:0;min-width:52px;text-align:center;text-transform:uppercase}.method-badge.GET{background:var(--get-bg);color:var(--get);border:1px solid rgba(16,185,129,.3)}.method-badge.POST{background:var(--post-bg);color:var(--post);border:1px solid rgba(79,110,247,.3)}.method-badge.PUT{background:var(--put-bg);color:var(--put);border:1px solid rgba(245,158,11,.3)}.method-badge.DELETE{background:var(--delete-bg);color:var(--delete);border:1px solid rgba(239,68,68,.3)}.method-badge.PATCH{background:var(--patch-bg);color:var(--patch);border:1px solid rgba(139,92,246,.3)}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@media(max-width:768px){.sidebar{transform:translate(-100%);z-index:200;transition:transform .3s ease}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.content-wrapper{padding:24px 16px 60px}.api-docs-hero{padding:24px}.api-docs-hero__title{font-size:1.5rem}.api-docs-hero__stats{gap:14px}.topbar__api-base,.topbar__version{display:none}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-deep);position:relative;overflow:hidden;padding:24px}.auth-page__orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;opacity:.5;animation:orbFloat 8s ease-in-out infinite}.auth-page__orb--1{width:500px;height:500px;background:radial-gradient(circle,rgba(79,110,247,.25),transparent 70%);top:-150px;left:-100px}.auth-page__orb--2{width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,.2),transparent 70%);bottom:-100px;right:-80px;animation-delay:-4s}@keyframes orbFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}.auth-container{width:100%;max-width:440px;display:flex;flex-direction:column;align-items:center;gap:24px;position:relative;z-index:1}.auth-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text-primary)}.auth-logo__icon{width:40px;height:40px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent),#7b5bf7);display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px #4f6ef780}.auth-logo__text{font-size:1.2rem;font-weight:700;letter-spacing:-.3px;color:var(--text-primary)}.auth-logo__text span{color:var(--text-accent)}.auth-card{width:100%;background:#111c33d9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px 32px;box-shadow:var(--shadow-lg),0 0 40px #4f6ef714;animation:cardIn .4s cubic-bezier(.34,1.56,.64,1) both}@keyframes cardIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-card__title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:6px}.auth-card__subtitle{font-size:.87rem;color:var(--text-muted);margin-bottom:28px}.auth-footer{font-size:.75rem;color:var(--text-muted);text-align:center}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.form-group:last-of-type{margin-bottom:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-label{font-size:.8rem;font-weight:500;color:var(--text-secondary);letter-spacing:.2px}.form-input-wrap{position:relative;display:flex;align-items:center}.form-input{width:100%;background:var(--bg-elevated);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:11px 14px;color:var(--text-primary);font-size:.88rem;font-family:Inter,sans-serif;transition:var(--transition);outline:none}.form-input.has-icon{padding-right:42px}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--accent);background:var(--bg-hover);box-shadow:0 0 0 3px var(--accent-light)}.form-input.error{border-color:var(--delete);box-shadow:0 0 0 3px #ef44441a}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-input-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;padding:2px;background:none;border:none;transition:var(--transition)}.form-input-icon:hover{color:var(--text-secondary)}.form-error{font-size:.76rem;color:var(--delete);display:flex;align-items:center;gap:4px;margin-top:2px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.form-server-error{background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md);padding:12px 16px;font-size:.82rem;color:#fca5a5;display:flex;align-items:flex-start;gap:8px;margin-bottom:20px;animation:fadeIn .2s ease}.form-success{background:#10b98114;border:1px solid rgba(16,185,129,.25);border-radius:var(--radius-md);padding:12px 16px;font-size:.82rem;color:#6ee7b7;display:flex;align-items:center;gap:8px;margin-bottom:20px;animation:fadeIn .2s ease}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:var(--radius-md);font-size:.88rem;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:var(--transition);border:none;outline:none;width:100%;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:#fff;opacity:0;transition:opacity .15s ease}.btn:active:after{opacity:.06}.btn:disabled{cursor:not-allowed;opacity:.65}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,#6b4df7 100%);color:#fff;box-shadow:0 4px 16px #4f6ef759}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-hover) 0%,#7a5cf7 100%);box-shadow:0 6px 24px #4f6ef780;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #4f6ef74d}.btn-ghost{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent)}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.form-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--text-muted);font-size:.78rem}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-switch{text-align:center;margin-top:20px;font-size:.83rem;color:var(--text-muted)}.auth-switch a{color:var(--text-accent);font-weight:500;margin-left:4px}.auth-switch a:hover{color:var(--accent-hover);text-decoration:underline}.profile-page{max-width:640px;margin:0 auto;padding:40px 32px 80px}.profile-header{display:flex;align-items:center;gap:20px;margin-bottom:36px;padding:28px;background:linear-gradient(135deg,var(--bg-surface),var(--bg-elevated));border:1px solid var(--border);border-radius:var(--radius-xl);position:relative;overflow:hidden}.profile-header:after{content:"";position:absolute;top:-40px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(79,110,247,.15),transparent 70%)}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#7b5bf7);display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 0 20px #4f6ef766;position:relative;z-index:1}.profile-header__info{position:relative;z-index:1}.profile-header__name{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin-bottom:2px}.profile-header__email{font-size:.85rem;color:var(--text-muted);margin-bottom:6px}.profile-role-badge{display:inline-flex;font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:100px;background:var(--accent-light);color:var(--text-accent);border:1px solid rgba(79,110,247,.25);text-transform:capitalize}.profile-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}.profile-card__title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}@media(max-width:480px){.auth-card{padding:24px 18px}.form-row{grid-template-columns:1fr;gap:0}.profile-page{padding:20px 16px 60px}.profile-header{flex-direction:column;text-align:center}}.hero-section{position:relative;border-radius:var(--radius-xl);overflow:hidden;padding:60px 40px;min-height:480px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;margin-bottom:48px;background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-elevated) 100%);border:1px solid var(--border)}.hero-section:before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(79,110,247,.15),transparent 70%);pointer-events:none}.hero-title{font-size:2.8rem;font-weight:800;color:var(--text-primary);margin-bottom:16px;letter-spacing:-.5px;position:relative;z-index:2}.hero-title span{background:linear-gradient(135deg,var(--accent) 0%,#a855f7 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-subtitle{font-size:1.1rem;color:var(--text-secondary);max-width:600px;margin-bottom:40px;position:relative;z-index:2}.search-bar-container{width:100%;max-width:860px;position:relative;z-index:10}.search-bar{display:flex;align-items:center;background:#0d1425d9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:100px;padding:8px 8px 8px 24px;box-shadow:var(--shadow-lg),0 0 40px #4f6ef71a;transition:var(--transition)}.search-bar:focus-within{border-color:var(--accent);box-shadow:var(--shadow-lg),0 0 0 3px var(--accent-light)}.search-bar__field{flex:1;display:flex;flex-direction:column;gap:2px;padding-right:16px}.search-bar__field--date{flex:.8;padding-left:16px}.search-bar__label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.search-bar__input-wrap{display:flex;align-items:center;gap:8px}.search-bar__icon{color:var(--text-secondary);flex-shrink:0}.search-bar__input{width:100%;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:.95rem;font-weight:500;font-family:inherit;padding:4px 0}.search-bar__input::placeholder{color:var(--text-muted)}.search-bar__input.date-picker::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.4;cursor:pointer;transition:var(--transition)}.search-bar__input.date-picker::-webkit-calendar-picker-indicator:hover{opacity:.8}.search-bar__divider{width:1px;height:36px;background:var(--border);margin:0 4px}.search-bar__submit{display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--accent) 0%,#6b4df7 100%);color:#fff;border:none;border-radius:100px;padding:14px 28px;font-size:.95rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:0 4px 16px #4f6ef766}.search-bar__submit:hover{transform:translateY(-1px);box-shadow:0 6px 20px #4f6ef780}.section-title{font-size:1.4rem;font-weight:700;color:var(--text-primary);margin-bottom:24px;display:flex;align-items:center;gap:10px}.cities-slider{display:flex;gap:16px;overflow-x:auto;padding-bottom:16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.cities-slider::-webkit-scrollbar{height:4px;display:none}.cities-slider:hover::-webkit-scrollbar{display:block}.cities-slider::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.city-card{min-width:160px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 16px;scroll-snap-align:start;text-align:center;transition:var(--transition);display:flex;flex-direction:column;align-items:center;gap:8px}.city-card:hover{border-color:var(--text-muted);transform:translateY(-2px);background:var(--bg-elevated)}.city-card__icon{width:48px;height:48px;border-radius:50%;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--text-accent);margin-bottom:4px}.city-card__name{font-size:1.05rem;font-weight:600;color:var(--text-primary)}.city-card__meta{font-size:.75rem;color:var(--text-muted)}.hotel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-bottom:60px}.hotel-card{display:flex;flex-direction:column;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);text-decoration:none;color:inherit}.hotel-card:hover{border-color:var(--text-muted);transform:translateY(-4px);box-shadow:var(--shadow-md)}.hotel-card__image{height:180px;background-size:cover;background-position:center;position:relative;border-bottom:1px solid var(--border)}.hotel-card__badge{position:absolute;top:12px;right:12px;background:#ef4444;color:#fff;font-size:.75rem;font-weight:700;padding:4px 10px;border-radius:100px;box-shadow:0 2px 8px #ef444466}.hotel-card__content{padding:18px;display:flex;flex-direction:column;flex:1}.hotel-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:6px}.hotel-card__title{font-size:1.05rem;font-weight:600;color:var(--text-primary);line-height:1.3;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.hotel-card__stars{display:flex;align-items:center;gap:4px;color:#fbbf24;font-size:.8rem;font-weight:600;background:#fbbf241a;padding:2px 6px;border-radius:4px}.hotel-card__location{display:flex;align-items:center;gap:4px;color:var(--text-secondary);font-size:.8rem;margin-bottom:16px}.hotel-card__footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--border-subtle)}.hotel-card__price-box{display:flex;flex-direction:column;align-items:flex-end}.hotel-card__price-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.hotel-card__price-row{display:flex;align-items:center;gap:8px}.hotel-card__price{font-size:1.3rem;font-weight:700;color:var(--text-accent)}.hotel-card__price-original{font-size:.85rem;color:var(--text-muted);text-decoration:line-through}.hotel-card__price-period{font-size:.75rem;color:var(--text-muted)}.hotel-details{display:flex;flex-direction:column;gap:32px}.hotel-details__hero{margin-bottom:16px}.hotel-details__title-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:12px}.hotel-details__breadcrumbs{font-size:.8rem;color:var(--text-muted);margin-bottom:16px;display:flex;align-items:center;gap:8px}.hotel-details__breadcrumbs a{color:var(--text-secondary)}.hotel-details__breadcrumbs a:hover{color:var(--text-accent)}.gallery-grid{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:200px 200px;gap:12px;border-radius:var(--radius-xl);overflow:hidden}.gallery-grid__main{grid-row:1 / -1;background:var(--bg-surface);background-size:cover;background-position:center}.gallery-grid__side{background:var(--bg-surface);background-size:cover;background-position:center}.hotel-details__layout{display:grid;grid-template-columns:2fr 1fr;gap:32px;align-items:start}.hotel-details__main section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;margin-bottom:24px}.hotel-details__main h2{font-size:1.25rem;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}.amenities-list{display:flex;flex-wrap:wrap;gap:10px}.amenity-tag{display:inline-flex;align-items:center;gap:6px;background:var(--bg-elevated);border:1px solid var(--border);padding:8px 14px;border-radius:100px;font-size:.85rem;color:var(--text-secondary)}.booking-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;position:sticky;top:100px}.booking-card h3{font-size:1.1rem;margin-bottom:20px}.availability-results{margin-top:24px;display:flex;flex-direction:column;gap:12px}.room-type-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;transition:var(--transition)}.room-type-card:hover{border-color:var(--accent)}.room-type-card__head{display:flex;justify-content:space-between;margin-bottom:8px}.room-type-card__name{font-weight:600;font-size:.95rem}.room-type-card__price{font-weight:700;color:var(--text-accent)}.room-type-card__meta{font-size:.8rem;color:var(--text-muted);display:flex;justify-content:space-between}.room-type-card__available{color:var(--get);font-weight:600}@media(max-width:900px){.hotel-details__layout{grid-template-columns:1fr}.booking-card{position:static}}@media(max-width:768px){.hero-section{padding:40px 24px;min-height:400px}.hero-title{font-size:2.2rem}.search-bar{flex-direction:column;border-radius:var(--radius-lg);padding:16px;gap:16px;align-items:stretch}.search-bar__divider{display:none}.search-bar__field{padding:0}.search-bar__input{padding:8px 0;border-bottom:1px solid var(--border)}.gallery-grid{grid-template-columns:1fr;grid-template-rows:250px}.gallery-grid__side{display:none}}
