.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);font-family:var(--font-family);font-weight:var(--font-weight-semibold);text-decoration:none;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden;white-space:nowrap;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%);opacity:0;transform:scale(0);transition:transform .4s ease-out,opacity .3s ease-out}.btn:active:after{opacity:1;transform:scale(2.5);transition:transform .1s ease-out,opacity .1s ease-out}.btn:focus-visible{outline:3px solid var(--color-primary-lighter);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-xs{min-height:32px;padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs);border-radius:var(--radius-md)}.btn-sm{min-height:var(--touch-target-min);padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-sm)}.btn-md{min-height:var(--touch-target-comfortable);padding:var(--spacing-3) var(--spacing-6);font-size:var(--font-size-base)}.btn-lg{min-height:56px;padding:var(--spacing-4) var(--spacing-8);font-size:var(--font-size-lg);border-radius:var(--radius-xl)}.btn-xl{min-height:64px;padding:var(--spacing-5) var(--spacing-10);font-size:var(--font-size-xl);border-radius:var(--radius-xl)}.btn-primary{background:var(--color-primary-gradient);color:var(--color-white);box-shadow:var(--shadow-sm),var(--shadow-primary)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);box-shadow:var(--shadow-md),var(--shadow-primary);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-xs)}.btn-accent{background:var(--color-accent-gradient);color:var(--color-white);box-shadow:var(--shadow-sm),var(--shadow-accent)}.btn-accent:hover:not(:disabled){background:linear-gradient(135deg,var(--color-accent-light) 0%,var(--color-accent) 100%);box-shadow:var(--shadow-md),var(--shadow-accent);transform:translateY(-1px)}.btn-secondary{background-color:var(--color-gray-100);color:var(--color-gray-700);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-200);color:var(--color-gray-800)}.btn-outline{background-color:transparent;border:2px solid var(--color-primary);color:var(--color-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary);color:var(--color-white);box-shadow:var(--shadow-primary)}.btn-outline-accent{background-color:transparent;border:2px solid var(--color-accent);color:var(--color-accent)}.btn-outline-accent:hover:not(:disabled){background-color:var(--color-accent);color:var(--color-white)}.btn-ghost{background-color:transparent;color:var(--color-gray-600)}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-gray-800)}.btn-ghost-primary{background-color:transparent;color:var(--color-primary)}.btn-ghost-primary:hover:not(:disabled){background-color:#1e3a5f14}.btn-danger{background-color:var(--color-error);color:var(--color-white);box-shadow:var(--shadow-sm),var(--shadow-error)}.btn-danger:hover:not(:disabled){background-color:var(--color-error-dark);box-shadow:var(--shadow-md),var(--shadow-error);transform:translateY(-1px)}.btn-success{background-color:var(--color-success);color:var(--color-white);box-shadow:var(--shadow-sm),var(--shadow-success)}.btn-success:hover:not(:disabled){background-color:var(--color-success-dark);box-shadow:var(--shadow-md),var(--shadow-success);transform:translateY(-1px)}.btn-glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);color:var(--color-gray-800);box-shadow:var(--glass-shadow)}.btn-glass:hover:not(:disabled){background:#ffffffe6}.btn-block{width:100%}.btn-icon{padding:0;aspect-ratio:1}.btn-icon.btn-sm{width:var(--touch-target-min)}.btn-icon.btn-md{width:var(--touch-target-comfortable)}.btn-icon.btn-lg{width:56px}.btn-rounded{border-radius:var(--radius-full)}.btn-loading{pointer-events:none;color:transparent!important}.btn-loading .btn-content{visibility:hidden}.btn-spinner{position:absolute;width:1.25em;height:1.25em;border:2px solid transparent;border-top-color:currentColor;border-right-color:currentColor;border-radius:50%;animation:btn-spin .6s linear infinite}.btn-loading .btn-spinner{color:var(--color-white)}.btn-secondary.btn-loading .btn-spinner,.btn-ghost.btn-loading .btn-spinner,.btn-outline.btn-loading .btn-spinner{color:var(--color-primary)}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-group{display:inline-flex}.btn-group .btn{border-radius:0}.btn-group .btn:first-child{border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.btn-group .btn:last-child{border-radius:0 var(--radius-lg) var(--radius-lg) 0}.btn-group .btn:not(:last-child){border-right:1px solid rgba(255,255,255,.2)}.fab{position:fixed;bottom:calc(var(--spacing-6) + var(--bottom-nav-safe-area));right:var(--spacing-6);width:var(--fab-size);height:var(--fab-size);border-radius:var(--radius-full);background:var(--color-accent-gradient);color:var(--color-white);box-shadow:var(--fab-shadow);z-index:var(--z-fixed);display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all var(--transition-normal)}.fab:hover{transform:scale(1.1);box-shadow:0 8px 24px #ff6b3559}.fab:active{transform:scale(.95)}.fab-sm{width:var(--fab-size-sm);height:var(--fab-size-sm)}.has-bottom-nav .fab{bottom:calc(var(--bottom-nav-height) + var(--spacing-4) + var(--bottom-nav-safe-area))}@media (max-width: 640px){.btn-sm{min-height:var(--touch-target-comfortable)}.fab{bottom:calc(var(--spacing-4) + var(--bottom-nav-safe-area));right:var(--spacing-4)}}.input-group{display:flex;flex-direction:column;gap:var(--spacing-2)}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700);display:flex;align-items:center;gap:var(--spacing-1)}.input-required{color:var(--color-error)}.input-optional{color:var(--color-gray-400);font-weight:var(--font-weight-normal);font-size:var(--font-size-xs)}.input-hint{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:calc(-1 * var(--spacing-1))}.input{width:100%;min-height:var(--touch-target-comfortable);padding:var(--spacing-3) var(--spacing-4);font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-gray-900);background-color:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-lg);transition:all var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none}.input::placeholder{color:var(--color-gray-400)}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a5f26}.input:hover:not(:focus):not(:disabled){border-color:var(--color-gray-400)}.input:disabled{background-color:var(--color-gray-100);color:var(--color-gray-500);cursor:not-allowed}.input:read-only{background-color:var(--color-gray-50)}.input-filled{background-color:var(--color-gray-100);border-color:transparent}.input-filled:focus{background-color:var(--color-white);border-color:var(--color-primary)}.input-underline{border-radius:0;border:none;border-bottom:2px solid var(--color-gray-300);padding-left:0;padding-right:0}.input-underline:focus{border-bottom-color:var(--color-primary);box-shadow:none}.input-sm{min-height:var(--touch-target-min);padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm)}.input-lg{min-height:56px;padding:var(--spacing-4) var(--spacing-5);font-size:var(--font-size-lg)}.input.input-error{border-color:var(--color-error);background-color:var(--color-error-light)}.input.input-error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #ef444426}.input-error-message{display:flex;align-items:center;gap:var(--spacing-1);font-size:var(--font-size-sm);color:var(--color-error)}.input-error-icon{flex-shrink:0;width:16px;height:16px}.input.input-success{border-color:var(--color-success)}.input.input-success:focus{box-shadow:0 0 0 3px #10b98126}.textarea{resize:vertical;min-height:120px;line-height:var(--line-height-relaxed)}.textarea-auto{resize:none;overflow:hidden}.select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748B' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-3) center;background-size:1.25rem;padding-right:var(--spacing-10)}.select:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%231E3A5F' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E")}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;top:50%;transform:translateY(-50%);color:var(--color-gray-400);pointer-events:none;display:flex;align-items:center;justify-content:center;width:20px;height:20px}.input-icon-left{left:var(--spacing-4)}.input-icon-right{right:var(--spacing-4)}.input-with-icon-left{padding-left:calc(var(--spacing-4) + 20px + var(--spacing-2))}.input-with-icon-right{padding-right:calc(var(--spacing-4) + 20px + var(--spacing-2))}.input-action{position:absolute;right:var(--spacing-2);top:50%;transform:translateY(-50%);background:none;border:none;padding:var(--spacing-2);color:var(--color-gray-400);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.input-action:hover{color:var(--color-gray-600);background-color:var(--color-gray-100)}.input-with-action{padding-right:calc(var(--spacing-4) + 32px)}.input-addon-group{display:flex}.input-addon{display:flex;align-items:center;padding:0 var(--spacing-4);background-color:var(--color-gray-100);border:1px solid var(--color-gray-300);color:var(--color-gray-600);font-size:var(--font-size-sm);white-space:nowrap}.input-addon-left{border-right:none;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.input-addon-right{border-left:none;border-radius:0 var(--radius-lg) var(--radius-lg) 0}.input-addon-group .input{flex:1}.input-addon-group .input:first-child{border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.input-addon-group .input:last-child{border-radius:0 var(--radius-lg) var(--radius-lg) 0}.input-addon-group .input:not(:first-child):not(:last-child){border-radius:0}.checkbox-group,.radio-group{display:flex;align-items:flex-start;gap:var(--spacing-3);min-height:var(--touch-target-min);padding:var(--spacing-2) 0;cursor:pointer}.checkbox-input,.radio-input{position:absolute;opacity:0;width:0;height:0}.checkbox-box,.radio-box{flex-shrink:0;width:20px;height:20px;border:2px solid var(--color-gray-300);background-color:var(--color-white);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.checkbox-box{border-radius:var(--radius-sm)}.radio-box{border-radius:var(--radius-full)}.checkbox-input:checked+.checkbox-box,.radio-input:checked+.radio-box{background-color:var(--color-primary);border-color:var(--color-primary)}.checkbox-input:focus+.checkbox-box,.radio-input:focus+.radio-box{box-shadow:0 0 0 3px #1e3a5f26}.checkbox-check{color:var(--color-white);transform:scale(0);transition:transform var(--transition-fast)}.checkbox-input:checked+.checkbox-box .checkbox-check{transform:scale(1)}.radio-dot{width:8px;height:8px;background-color:var(--color-white);border-radius:var(--radius-full);transform:scale(0);transition:transform var(--transition-fast)}.radio-input:checked+.radio-box .radio-dot{transform:scale(1)}.checkbox-label,.radio-label{font-size:var(--font-size-base);color:var(--color-gray-700);line-height:var(--line-height-normal)}.switch-group{display:flex;align-items:center;gap:var(--spacing-3);min-height:var(--touch-target-min);cursor:pointer}.switch-track{position:relative;width:48px;height:28px;background-color:var(--color-gray-300);border-radius:var(--radius-full);transition:background-color var(--transition-fast)}.switch-input:checked+.switch-track{background-color:var(--color-primary)}.switch-input:focus+.switch-track{box-shadow:0 0 0 3px #1e3a5f26}.switch-thumb{position:absolute;top:2px;left:2px;width:24px;height:24px;background-color:var(--color-white);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.switch-input:checked+.switch-track .switch-thumb{transform:translate(20px)}.file-input-wrapper{position:relative}.file-input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.file-input-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-3);padding:var(--spacing-8);border:2px dashed var(--color-gray-300);border-radius:var(--radius-xl);background-color:var(--color-gray-50);transition:all var(--transition-fast);text-align:center}.file-input-wrapper:hover .file-input-label{border-color:var(--color-primary);background-color:#1e3a5f08}.file-input-icon{width:48px;height:48px;color:var(--color-gray-400)}.file-input-text{font-size:var(--font-size-sm);color:var(--color-gray-600)}.file-input-text strong{color:var(--color-primary)}.search-input{border-radius:var(--radius-full);padding-left:calc(var(--spacing-4) + 24px);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394A3B8' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:var(--spacing-4) center;background-size:20px}.search-input:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%231E3A5F' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z'/%3E%3C/svg%3E")}@media (max-width: 640px){.input{font-size:16px}.input-group{gap:var(--spacing-1)}}.card{background-color:var(--color-white);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal)}.card-default{border:1px solid var(--color-gray-200)}.card-elevated{box-shadow:var(--shadow-md)}.card-elevated:hover{box-shadow:var(--shadow-lg)}.card-outlined{border:2px solid var(--color-gray-200)}.card-flat{background-color:var(--color-gray-50)}.card-glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow)}.card-gradient{position:relative;background:var(--color-white);border:none}.card-gradient:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-xl);padding:2px;background:var(--color-primary-gradient);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude}.card-primary{background:var(--color-primary-gradient);color:var(--color-white)}.card-accent{background:var(--color-accent-gradient);color:var(--color-white)}.card-success{background-color:var(--color-success-light);border:1px solid var(--color-success)}.card-warning{background-color:var(--color-warning-light);border:1px solid var(--color-warning)}.card-error{background-color:var(--color-error-light);border:1px solid var(--color-error)}.card-info{background-color:var(--color-info-light);border:1px solid var(--color-info)}.card-clickable{cursor:pointer;-webkit-tap-highlight-color:transparent}.card-clickable:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.card-clickable:active{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-selectable{cursor:pointer;position:relative}.card-selectable:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid transparent;border-radius:var(--radius-xl);transition:border-color var(--transition-fast);pointer-events:none}.card-selectable:hover:after{border-color:var(--color-gray-300)}.card-selectable.selected:after{border-color:var(--color-primary)}.card-selectable.selected{background-color:#1e3a5f08}.card-padding-none{padding:0}.card-padding-xs{padding:var(--spacing-2)}.card-padding-sm{padding:var(--spacing-3)}.card-padding-md{padding:var(--spacing-4)}.card-padding-lg{padding:var(--spacing-6)}.card-padding-xl{padding:var(--spacing-8)}.card-header{padding:var(--spacing-4) var(--spacing-5);border-bottom:1px solid var(--color-gray-100);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-4)}.card-header-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin:0}.card-header-subtitle{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:var(--spacing-1) 0 0 0}.card-header-actions{display:flex;align-items:center;gap:var(--spacing-2)}.card-body{padding:var(--spacing-5)}.card-footer{padding:var(--spacing-4) var(--spacing-5);border-top:1px solid var(--color-gray-100);background-color:var(--color-gray-50);display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-3)}.card-footer-left{justify-content:flex-start}.card-footer-center{justify-content:center}.card-footer-between{justify-content:space-between}.card-image{position:relative;overflow:hidden}.card-image img{width:100%;height:auto;display:block;object-fit:cover;transition:transform var(--transition-slow)}.card-clickable:hover .card-image img{transform:scale(1.05)}.card-image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 50%);display:flex;align-items:flex-end;padding:var(--spacing-4)}.card-image-overlay-full{background:#0006;align-items:center;justify-content:center}.card-image-badge{position:absolute;top:var(--spacing-3);left:var(--spacing-3)}.card-image-actions{position:absolute;top:var(--spacing-3);right:var(--spacing-3);display:flex;gap:var(--spacing-2)}.card-horizontal{display:flex;flex-direction:row}.card-horizontal .card-image{flex-shrink:0;width:200px}.card-horizontal .card-image img{height:100%}.card-horizontal .card-content{flex:1;display:flex;flex-direction:column}@media (max-width: 640px){.card-horizontal{flex-direction:column}.card-horizontal .card-image{width:100%;max-height:200px}}.card-stack{position:relative}.card-stack:before,.card-stack:after{content:"";position:absolute;left:50%;transform:translate(-50%);width:calc(100% - 16px);height:100%;background-color:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);z-index:-1}.card-stack:before{top:8px;width:calc(100% - 32px);z-index:-2}.card-stack:after{top:4px}.card-feature{text-align:center;padding:var(--spacing-8)}.card-feature-icon{width:64px;height:64px;margin:0 auto var(--spacing-4);display:flex;align-items:center;justify-content:center;background:var(--color-primary-gradient);border-radius:var(--radius-xl);color:var(--color-white)}.card-feature-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin:0 0 var(--spacing-2) 0}.card-feature-description{font-size:var(--font-size-base);color:var(--color-gray-600);margin:0;line-height:var(--line-height-relaxed)}.card-pricing{text-align:center;padding:var(--spacing-8);position:relative}.card-pricing-popular{border:2px solid var(--color-primary)}.card-pricing-badge{position:absolute;top:0;left:50%;transform:translate(-50%,-50%);background:var(--color-primary-gradient);color:var(--color-white);padding:var(--spacing-1) var(--spacing-4);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.card-pricing-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin:0 0 var(--spacing-2) 0}.card-pricing-price{display:flex;align-items:baseline;justify-content:center;gap:var(--spacing-1);margin-bottom:var(--spacing-4)}.card-pricing-amount{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.card-pricing-period{font-size:var(--font-size-base);color:var(--color-gray-500)}.card-pricing-features{list-style:none;padding:0;margin:0 0 var(--spacing-6) 0;text-align:left}.card-pricing-feature{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) 0;color:var(--color-gray-600)}.card-pricing-feature-icon{color:var(--color-success);flex-shrink:0}.card-stat{padding:var(--spacing-5)}.card-stat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-3)}.card-stat-label{font-size:var(--font-size-sm);color:var(--color-gray-500);font-weight:var(--font-weight-medium)}.card-stat-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:var(--color-primary-lighter);background:#1e3a5f1a;border-radius:var(--radius-lg);color:var(--color-primary)}.card-stat-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);line-height:1}.card-stat-trend{display:flex;align-items:center;gap:var(--spacing-1);margin-top:var(--spacing-2);font-size:var(--font-size-sm)}.card-stat-trend-up{color:var(--color-success)}.card-stat-trend-down{color:var(--color-error)}.card-profile{text-align:center;padding:var(--spacing-6)}.card-profile-avatar{width:96px;height:96px;margin:0 auto var(--spacing-4);border-radius:var(--radius-full);overflow:hidden;border:3px solid var(--color-white);box-shadow:var(--shadow-md)}.card-profile-avatar img{width:100%;height:100%;object-fit:cover}.card-profile-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin:0 0 var(--spacing-1) 0}.card-profile-role{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:0}@media (max-width: 640px){.card-padding-lg,.card-padding-xl,.card-header,.card-body,.card-footer{padding:var(--spacing-4)}.card-feature,.card-pricing{padding:var(--spacing-6)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--color-bg-overlay);display:flex;align-items:center;justify-content:center;padding:var(--spacing-4);z-index:var(--z-modal);animation:modal-fade-in var(--transition-fast) ease-out;-webkit-overflow-scrolling:touch;overflow-y:auto}@media (max-width: 640px){.modal-overlay{align-items:flex-end;padding:0}}.modal{background-color:var(--color-white);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);max-height:calc(100vh - var(--spacing-8));overflow:hidden;display:flex;flex-direction:column;animation:modal-slide-up var(--transition-normal) var(--transition-spring);position:relative}@media (max-width: 640px){.modal{width:100%;max-width:100%;max-height:calc(100vh - var(--spacing-12));border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;margin-bottom:0;animation:modal-slide-up-mobile var(--transition-normal) ease-out}.modal:before{content:"";position:absolute;top:var(--spacing-2);left:50%;transform:translate(-50%);width:40px;height:4px;background-color:var(--color-gray-300);border-radius:var(--radius-full);z-index:10}}.modal-xs{width:100%;max-width:320px}.modal-sm{width:100%;max-width:400px}.modal-md{width:100%;max-width:500px}.modal-lg{width:100%;max-width:700px}.modal-xl{width:100%;max-width:900px}.modal-full{width:calc(100% - var(--spacing-8));max-width:none;height:calc(100vh - var(--spacing-8));max-height:none}@media (max-width: 640px){.modal-xs,.modal-sm,.modal-md,.modal-lg,.modal-xl{max-width:100%}}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-4);padding:var(--spacing-5) var(--spacing-6);border-bottom:1px solid var(--color-gray-100);flex-shrink:0}@media (max-width: 640px){.modal-header{padding:var(--spacing-6) var(--spacing-4) var(--spacing-4)}}.modal-header-content{flex:1;min-width:0}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin:0;line-height:var(--line-height-tight)}.modal-subtitle{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:var(--spacing-1) 0 0 0}.modal-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:var(--touch-target-min);height:var(--touch-target-min);background:none;border:none;color:var(--color-gray-400);cursor:pointer;border-radius:var(--radius-lg);transition:all var(--transition-fast);margin:calc(-1 * var(--spacing-2))}.modal-close:hover{background-color:var(--color-gray-100);color:var(--color-gray-600)}.modal-close:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.modal-body{padding:var(--spacing-6);overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}@media (max-width: 640px){.modal-body{padding:var(--spacing-4);padding-bottom:calc(var(--spacing-4) + var(--bottom-nav-safe-area))}}.modal-body-flush{padding:0}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-gray-100);background-color:var(--color-gray-50);flex-shrink:0}@media (max-width: 640px){.modal-footer{padding:var(--spacing-4);padding-bottom:calc(var(--spacing-4) + var(--bottom-nav-safe-area));flex-direction:column}.modal-footer>*{width:100%}}.modal-footer-left{justify-content:flex-start}.modal-footer-center{justify-content:center}.modal-footer-between{justify-content:space-between}.modal-centered .modal-body{display:flex;flex-direction:column;align-items:center;text-align:center}.modal-alert{max-width:400px;text-align:center}.modal-alert .modal-header{border-bottom:none;padding-bottom:0}.modal-alert .modal-body{padding-top:var(--spacing-2)}.modal-alert-icon{width:64px;height:64px;margin:0 auto var(--spacing-4);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full)}.modal-alert-icon-success{background-color:var(--color-success-light);color:var(--color-success)}.modal-alert-icon-error{background-color:var(--color-error-light);color:var(--color-error)}.modal-alert-icon-warning{background-color:var(--color-warning-light);color:var(--color-warning)}.modal-alert-icon-info{background-color:var(--color-info-light);color:var(--color-info)}.modal-alert-message{font-size:var(--font-size-base);color:var(--color-gray-600);margin:0;line-height:var(--line-height-relaxed)}.modal-image{background-color:var(--color-black);max-width:90vw;max-height:90vh}.modal-image .modal-body{padding:0;display:flex;align-items:center;justify-content:center}.modal-image img{max-width:100%;max-height:100%;object-fit:contain}.modal-image .modal-close{position:absolute;top:var(--spacing-4);right:var(--spacing-4);background-color:#00000080;color:var(--color-white)}.modal-image .modal-close:hover{background-color:#000000b3}.modal-drawer{position:fixed;top:0;right:0;bottom:0;max-width:480px;max-height:none;border-radius:var(--radius-2xl) 0 0 var(--radius-2xl);animation:modal-slide-left var(--transition-normal) ease-out}.modal-drawer-left{right:auto;left:0;border-radius:0 var(--radius-2xl) var(--radius-2xl) 0;animation:modal-slide-right var(--transition-normal) ease-out}@media (max-width: 640px){.modal-drawer,.modal-drawer-left{max-width:100%;border-radius:0}}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modal-slide-up-mobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes modal-slide-left{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes modal-slide-right{0%{transform:translate(-100%)}to{transform:translate(0)}}.modal-overlay.exiting{animation:modal-fade-out var(--transition-fast) ease-in forwards}.modal.exiting{animation:modal-slide-down var(--transition-fast) ease-in forwards}@keyframes modal-fade-out{to{opacity:0}}@keyframes modal-slide-down{to{opacity:0;transform:translateY(16px) scale(.98)}}.modal-overlay+.modal-overlay{background-color:#0f172a66}.modal[aria-hidden=true]{display:none}.modal:focus{outline:none}.rating{display:inline-flex;align-items:center;gap:var(--spacing-2)}.rating-stars{display:flex;gap:var(--spacing-1)}.star{display:inline-flex;align-items:center;justify-content:center;color:var(--color-gray-200);transition:all var(--transition-fast)}.star svg{display:block}.star-filled{color:var(--color-warning)}.star-half{position:relative}.star-half:before{content:"";position:absolute;left:0;top:0;width:50%;height:100%;overflow:hidden}.star-half .star-filled-half{position:absolute;left:0;top:0;width:50%;overflow:hidden;color:var(--color-warning)}.rating-interactive .star{cursor:pointer;-webkit-tap-highlight-color:transparent}.rating-interactive .star:hover{transform:scale(1.15)}.rating-interactive .star:active{transform:scale(1.05)}.rating-interactive:hover .star{color:var(--color-gray-300)}.rating-interactive .star:hover,.rating-interactive .star:hover~.star-reverse,.rating-interactive .star.star-hovered{color:var(--color-warning)}.rating-interactive .star:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}.rating-xs .star svg{width:12px;height:12px}.rating-sm .star svg{width:16px;height:16px}.rating-md .star svg{width:20px;height:20px}.rating-lg .star svg{width:24px;height:24px}.rating-xl .star svg{width:32px;height:32px}.rating-value{font-weight:var(--font-weight-semibold);color:var(--color-gray-900);line-height:1}.rating-xs .rating-value{font-size:var(--font-size-xs)}.rating-sm .rating-value{font-size:var(--font-size-sm)}.rating-md .rating-value{font-size:var(--font-size-base)}.rating-lg .rating-value{font-size:var(--font-size-lg)}.rating-xl .rating-value{font-size:var(--font-size-xl)}.rating-count{font-size:var(--font-size-sm);color:var(--color-gray-500);font-weight:var(--font-weight-normal)}.rating-count:before{content:"("}.rating-count:after{content:")"}.rating-labeled{flex-direction:column;align-items:flex-start;gap:var(--spacing-1)}.rating-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.rating-compact .rating-value,.rating-compact .rating-count{display:none}.rating-inline{gap:var(--spacing-1)}.rating-stacked{flex-direction:column;align-items:center;gap:var(--spacing-1)}.rating-stacked .rating-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.rating-breakdown{display:flex;flex-direction:column;gap:var(--spacing-2);width:100%}.rating-breakdown-row{display:flex;align-items:center;gap:var(--spacing-3)}.rating-breakdown-label{width:24px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-600);text-align:right}.rating-breakdown-bar{flex:1;height:8px;background-color:var(--color-gray-100);border-radius:var(--radius-full);overflow:hidden}.rating-breakdown-fill{height:100%;background:var(--color-warning);border-radius:var(--radius-full);transition:width var(--transition-slow)}.rating-breakdown-count{width:40px;font-size:var(--font-size-sm);color:var(--color-gray-500)}.rating-summary{display:flex;gap:var(--spacing-8);padding:var(--spacing-6);background-color:var(--color-gray-50);border-radius:var(--radius-xl)}.rating-summary-score{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.rating-summary-value{font-size:var(--font-size-5xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);line-height:1}.rating-summary-stars{margin-top:var(--spacing-2)}.rating-summary-total{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-top:var(--spacing-1)}.rating-summary-breakdown{flex:1}@media (max-width: 640px){.rating-summary{flex-direction:column;gap:var(--spacing-6)}}.rating-gold .star-filled{color:#f59e0b}.rating-orange .star-filled{color:var(--color-accent)}.rating-primary .star-filled{color:var(--color-primary)}.rating-disabled{opacity:.5;pointer-events:none}.rating-badge{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);background-color:var(--color-warning-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-warning-dark)}.rating-badge .star{color:var(--color-warning)}.rating-badge .star svg{width:14px;height:14px}.loading{display:inline-flex;align-items:center;justify-content:center}.loading-spinner{border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:loading-spin .8s linear infinite}.loading-xs .loading-spinner{width:16px;height:16px;border-width:2px}.loading-sm .loading-spinner{width:20px;height:20px;border-width:2px}.loading-md .loading-spinner{width:32px;height:32px;border-width:3px}.loading-lg .loading-spinner{width:48px;height:48px;border-width:4px}.loading-xl .loading-spinner{width:64px;height:64px;border-width:4px}.loading-primary .loading-spinner{border-top-color:var(--color-primary)}.loading-accent .loading-spinner{border-top-color:var(--color-accent)}.loading-white .loading-spinner{border-color:#ffffff4d;border-top-color:var(--color-white)}.loading-dots{display:flex;align-items:center;gap:var(--spacing-1)}.loading-dot{width:8px;height:8px;background-color:var(--color-primary);border-radius:50%;animation:loading-bounce 1.4s ease-in-out infinite both}.loading-dot:nth-child(1){animation-delay:-.32s}.loading-dot:nth-child(2){animation-delay:-.16s}.loading-dot:nth-child(3){animation-delay:0s}.loading-sm .loading-dot{width:6px;height:6px}.loading-lg .loading-dot{width:12px;height:12px}.loading-pulse{width:40px;height:40px;background-color:var(--color-primary);border-radius:50%;animation:loading-pulse 1.5s ease-in-out infinite}.loading-sm .loading-pulse{width:24px;height:24px}.loading-lg .loading-pulse{width:56px;height:56px}.loading-bars{display:flex;align-items:flex-end;gap:3px;height:24px}.loading-bar{width:4px;background-color:var(--color-primary);border-radius:var(--radius-sm);animation:loading-bars 1s ease-in-out infinite}.loading-bar:nth-child(1){animation-delay:0s}.loading-bar:nth-child(2){animation-delay:.1s}.loading-bar:nth-child(3){animation-delay:.2s}.loading-bar:nth-child(4){animation-delay:.3s}.loading-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-4);text-align:center}.loading-message{font-size:var(--font-size-base);color:var(--color-gray-600);max-width:280px}.loading-submessage{font-size:var(--font-size-sm);color:var(--color-gray-400)}.loading-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-4);background-color:var(--color-bg-primary)}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#ffffffe6;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn var(--transition-fast)}.loading-overlay-dark{background-color:#0f172acc}.loading-overlay-dark .loading-message{color:var(--color-gray-300)}.loading-inline{display:inline-flex;align-items:center;gap:var(--spacing-2)}.loading-inline .loading-spinner{width:16px;height:16px;border-width:2px}.loading-inline-text{font-size:var(--font-size-sm);color:var(--color-gray-600)}.loading-button{width:1em;height:1em;border:2px solid transparent;border-top-color:currentColor;border-right-color:currentColor;border-radius:50%;animation:loading-spin .6s linear infinite}.loading-section{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;padding:var(--spacing-8);background-color:var(--color-gray-50);border-radius:var(--radius-xl)}.skeleton{background:linear-gradient(90deg,var(--color-gray-200) 0%,var(--color-gray-100) 50%,var(--color-gray-200) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-text{height:1em;margin-bottom:var(--spacing-2)}.skeleton-text:last-child{width:70%}.skeleton-title{height:1.5em;width:60%;margin-bottom:var(--spacing-3)}.skeleton-avatar{width:48px;height:48px;border-radius:50%}.skeleton-avatar-sm{width:32px;height:32px}.skeleton-avatar-lg{width:64px;height:64px}.skeleton-image{width:100%;aspect-ratio:16/9;border-radius:var(--radius-lg)}.skeleton-button{width:120px;height:44px;border-radius:var(--radius-lg)}.skeleton-card{padding:var(--spacing-4);background-color:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-gray-200)}.loading-progress{width:100%;height:4px;background-color:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.loading-progress-bar{height:100%;background:var(--color-primary-gradient);border-radius:var(--radius-full);transition:width var(--transition-normal)}.loading-progress-indeterminate .loading-progress-bar{width:30%;animation:loading-progress 1.5s ease-in-out infinite}.loading-progress-labeled{display:flex;flex-direction:column;gap:var(--spacing-2)}.loading-progress-label{display:flex;justify-content:space-between;font-size:var(--font-size-sm);color:var(--color-gray-600)}.typing-indicator{display:flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-3) var(--spacing-4);background-color:var(--color-gray-100);border-radius:var(--radius-2xl);width:fit-content}.typing-dot{width:8px;height:8px;background-color:var(--color-gray-400);border-radius:50%;animation:typing 1.4s ease-in-out infinite}.typing-dot:nth-child(1){animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes loading-spin{to{transform:rotate(360deg)}}@keyframes loading-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@keyframes loading-pulse{0%{transform:scale(0);opacity:1}to{transform:scale(1);opacity:0}}@keyframes loading-bars{0%,to{height:30%}50%{height:100%}}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes loading-progress{0%{transform:translate(-100%)}to{transform:translate(400%)}}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.navbar{position:sticky;top:0;left:0;right:0;background-color:var(--color-white);border-bottom:1px solid var(--color-gray-100);z-index:var(--z-sticky);transition:all var(--transition-normal)}.navbar-glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom-color:#fff3}.navbar-transparent{background-color:transparent;border-bottom-color:transparent}.navbar-elevated{box-shadow:var(--shadow-md)}.navbar-container{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 var(--spacing-4);max-width:var(--container-xl);margin:0 auto}@media (min-width: 768px){.navbar-container{height:72px;padding:0 var(--spacing-6)}}.navbar-brand{display:flex;align-items:center;gap:var(--spacing-3);text-decoration:none;flex-shrink:0}.navbar-logo{display:flex;align-items:center}.navbar-logo img{height:40px;width:auto}@media (min-width: 768px){.navbar-logo img{height:48px}}.navbar-logo-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary);text-decoration:none;letter-spacing:var(--letter-spacing-tight)}.navbar-logo-text:hover{color:var(--color-primary-light)}.navbar-menu{display:none;align-items:center;gap:var(--spacing-8)}@media (min-width: 768px){.navbar-menu{display:flex}}.navbar-links{display:flex;align-items:center;list-style:none;gap:var(--spacing-1);margin:0;padding:0}.navbar-link{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-gray-600);text-decoration:none;border-radius:var(--radius-lg);transition:all var(--transition-fast);white-space:nowrap}.navbar-link:hover{color:var(--color-primary);background-color:var(--color-gray-50)}.navbar-link.active{color:var(--color-primary);background-color:#1e3a5f14}.navbar-link-icon{width:20px;height:20px;flex-shrink:0}.navbar-link-dropdown:after{content:"";width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid currentColor;margin-left:var(--spacing-1);transition:transform var(--transition-fast)}.navbar-link-dropdown[aria-expanded=true]:after{transform:rotate(180deg)}.navbar-actions{display:flex;align-items:center;gap:var(--spacing-2)}@media (min-width: 768px){.navbar-actions{gap:var(--spacing-3)}}.navbar-user{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-1);border-radius:var(--radius-full);cursor:pointer;transition:background-color var(--transition-fast)}.navbar-user:hover{background-color:var(--color-gray-100)}.navbar-avatar{width:36px;height:36px;border-radius:var(--radius-full);overflow:hidden;background-color:var(--color-gray-200)}.navbar-avatar img{width:100%;height:100%;object-fit:cover}.navbar-user-info{display:none}@media (min-width: 768px){.navbar-user-info{display:flex;flex-direction:column;align-items:flex-start}.navbar-user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-900);line-height:1.2}.navbar-user-role{font-size:var(--font-size-xs);color:var(--color-gray-500);line-height:1.2}}.navbar-notification{position:relative}.navbar-notification-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;padding:0 var(--spacing-1);background-color:var(--color-error);color:var(--color-white);font-size:10px;font-weight:var(--font-weight-bold);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;border:2px solid var(--color-white)}.navbar-toggle{display:flex;align-items:center;justify-content:center;width:var(--touch-target-min);height:var(--touch-target-min);background:none;border:none;cursor:pointer;border-radius:var(--radius-lg);transition:background-color var(--transition-fast);-webkit-tap-highlight-color:transparent}.navbar-toggle:hover{background-color:var(--color-gray-100)}@media (min-width: 768px){.navbar-toggle{display:none}}.hamburger{display:block;width:20px;height:2px;background-color:var(--color-gray-700);position:relative;transition:background-color var(--transition-fast);border-radius:var(--radius-full)}.hamburger:before,.hamburger:after{content:"";position:absolute;left:0;width:20px;height:2px;background-color:var(--color-gray-700);border-radius:var(--radius-full);transition:transform var(--transition-normal)}.hamburger:before{top:-6px}.hamburger:after{bottom:-6px}.hamburger.open{background-color:transparent}.hamburger.open:before{transform:translateY(6px) rotate(45deg)}.hamburger.open:after{transform:translateY(-6px) rotate(-45deg)}.navbar-mobile-menu{position:fixed;top:64px;left:0;right:0;bottom:0;background-color:var(--color-white);padding:var(--spacing-4);overflow-y:auto;z-index:var(--z-modal);transform:translate(100%);transition:transform var(--transition-normal);-webkit-overflow-scrolling:touch}.navbar-mobile-menu.open{transform:translate(0)}.navbar-mobile-links{list-style:none;padding:0;margin:0 0 var(--spacing-6) 0}.navbar-mobile-link{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-3);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-gray-700);text-decoration:none;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.navbar-mobile-link:hover,.navbar-mobile-link:active{background-color:var(--color-gray-50);color:var(--color-primary)}.navbar-mobile-link.active{background-color:#1e3a5f14;color:var(--color-primary)}.navbar-mobile-link-icon{width:24px;height:24px;color:var(--color-gray-400)}.navbar-mobile-link.active .navbar-mobile-link-icon{color:var(--color-primary)}.navbar-mobile-divider{height:1px;background-color:var(--color-gray-200);margin:var(--spacing-4) 0}.navbar-mobile-actions{display:flex;flex-direction:column;gap:var(--spacing-3)}.navbar-dropdown{position:relative}.navbar-dropdown-menu{position:absolute;top:100%;left:50%;transform:translate(-50%) translateY(8px);min-width:200px;background-color:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:1px solid var(--color-gray-100);padding:var(--spacing-2);opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:var(--z-dropdown)}.navbar-dropdown:hover .navbar-dropdown-menu,.navbar-dropdown:focus-within .navbar-dropdown-menu{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.navbar-dropdown-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-gray-700);text-decoration:none;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.navbar-dropdown-item:hover{background-color:var(--color-gray-50);color:var(--color-primary)}.navbar-dropdown-item-icon{width:18px;height:18px;color:var(--color-gray-400)}.navbar-dropdown-item:hover .navbar-dropdown-item-icon{color:var(--color-primary)}.navbar-dropdown-divider{height:1px;background-color:var(--color-gray-100);margin:var(--spacing-2) 0}.navbar-search{display:none;position:relative;flex:1;max-width:400px}@media (min-width: 1024px){.navbar-search{display:block}}.navbar-search-input{width:100%;height:40px;padding:0 var(--spacing-4) 0 calc(var(--spacing-4) + 20px);font-size:var(--font-size-sm);border:1px solid var(--color-gray-200);border-radius:var(--radius-full);background-color:var(--color-gray-50);transition:all var(--transition-fast)}.navbar-search-input:focus{outline:none;border-color:var(--color-primary);background-color:var(--color-white);box-shadow:0 0 0 3px #1e3a5f1a}.navbar-search-icon{position:absolute;left:var(--spacing-4);top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--color-gray-400);pointer-events:none}.navbar-breadcrumb{background-color:var(--color-gray-50);border-bottom:1px solid var(--color-gray-100);padding:var(--spacing-3) 0}.navbar-breadcrumb-container{display:flex;align-items:center;gap:var(--spacing-2);padding:0 var(--spacing-4);max-width:var(--container-xl);margin:0 auto;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.navbar-breadcrumb-container::-webkit-scrollbar{display:none}.navbar-breadcrumb-item{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-500);white-space:nowrap}.navbar-breadcrumb-link{color:var(--color-gray-500);text-decoration:none;transition:color var(--transition-fast)}.navbar-breadcrumb-link:hover{color:var(--color-primary)}.navbar-breadcrumb-separator{color:var(--color-gray-300)}.navbar-breadcrumb-current{color:var(--color-gray-900);font-weight:var(--font-weight-medium)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-nav-height) + var(--bottom-nav-safe-area));padding-bottom:var(--bottom-nav-safe-area);background-color:var(--color-white);border-top:1px solid var(--color-gray-100);display:flex;align-items:flex-start;justify-content:space-around;z-index:var(--z-fixed)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-1);padding:var(--spacing-2) var(--spacing-3);min-width:64px;height:var(--bottom-nav-height);text-decoration:none;color:var(--color-gray-500);transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent}.bottom-nav-item:active{transform:scale(.95)}.bottom-nav-icon{width:24px;height:24px}.bottom-nav-label{font-size:10px;font-weight:var(--font-weight-medium);line-height:1}.bottom-nav-action{position:relative;top:-16px;width:56px;height:56px;border-radius:var(--radius-full);background:var(--color-accent-gradient);color:var(--color-white);border:4px solid var(--color-white);box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.bottom-nav-action:active{transform:scale(.95)}.bottom-nav-action-icon{width:24px;height:24px}.alert{display:flex;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-4);border-radius:var(--radius-lg);border-left:4px solid;animation:alert-slide-in var(--transition-normal) ease-out}.alert-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.alert-content{flex:1;min-width:0}.alert-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-1) 0;line-height:var(--line-height-tight)}.alert-message{margin:0;font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.alert-actions{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-3)}.alert-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;margin:calc(-1 * var(--spacing-1)) calc(-1 * var(--spacing-1)) 0 0;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;opacity:.6;transition:all var(--transition-fast)}.alert-close:hover{opacity:1;background-color:#0000000d}.alert-success{background-color:var(--color-success-light);border-color:var(--color-success);color:#065f46}.alert-success .alert-icon{color:var(--color-success)}.alert-success .alert-title{color:#065f46}.alert-error{background-color:var(--color-error-light);border-color:var(--color-error);color:#991b1b}.alert-error .alert-icon{color:var(--color-error)}.alert-error .alert-title{color:#991b1b}.alert-warning{background-color:var(--color-warning-light);border-color:var(--color-warning);color:#92400e}.alert-warning .alert-icon{color:var(--color-warning)}.alert-warning .alert-title{color:#92400e}.alert-info{background-color:var(--color-info-light);border-color:var(--color-info);color:#1e40af}.alert-info .alert-icon{color:var(--color-info)}.alert-info .alert-title{color:#1e40af}.alert-neutral{background-color:var(--color-gray-100);border-color:var(--color-gray-400);color:var(--color-gray-700)}.alert-neutral .alert-icon{color:var(--color-gray-500)}.alert-neutral .alert-title{color:var(--color-gray-900)}.alert-filled{border-left:none;color:var(--color-white)}.alert-filled.alert-success{background-color:var(--color-success)}.alert-filled.alert-error{background-color:var(--color-error)}.alert-filled.alert-warning{background-color:var(--color-warning);color:#1f2937}.alert-filled.alert-info{background-color:var(--color-info)}.alert-filled .alert-icon,.alert-filled .alert-title,.alert-filled .alert-message{color:inherit}.alert-filled.alert-warning .alert-icon,.alert-filled.alert-warning .alert-title,.alert-filled.alert-warning .alert-message{color:#1f2937}.alert-outlined{background-color:transparent;border:1px solid;border-left-width:4px}.alert-outlined.alert-success{border-color:var(--color-success)}.alert-outlined.alert-error{border-color:var(--color-error)}.alert-outlined.alert-warning{border-color:var(--color-warning)}.alert-outlined.alert-info{border-color:var(--color-info)}.alert-compact{padding:var(--spacing-3);gap:var(--spacing-2)}.alert-compact .alert-icon{width:20px;height:20px}.alert-compact .alert-title{font-size:var(--font-size-sm)}.alert-compact .alert-message{font-size:var(--font-size-xs)}.alert-inline{display:inline-flex;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);border-left:none}.alert-inline .alert-icon{width:18px;height:18px}.alert-inline .alert-title{font-size:var(--font-size-sm);margin:0}.alert-inline .alert-message{display:none}.alert-banner{border-radius:0;border-left:none;border-bottom:1px solid}.alert-banner.alert-success{border-bottom-color:#05966933}.alert-banner.alert-error{border-bottom-color:#dc262633}.alert-banner.alert-warning{border-bottom-color:#d9770633}.alert-banner.alert-info{border-bottom-color:#2563eb33}.alert-toast{min-width:300px;max-width:420px;background-color:var(--color-white);border:1px solid var(--color-gray-200);border-left-width:4px;box-shadow:var(--shadow-lg)}.alert-toast .alert-message{color:var(--color-gray-600)}.toast-container{position:fixed;z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--spacing-3);padding:var(--spacing-4);pointer-events:none}.toast-container>*{pointer-events:auto}.toast-container-top-right{top:0;right:0}.toast-container-top-left{top:0;left:0}.toast-container-bottom-right{bottom:0;right:0}.toast-container-bottom-left{bottom:0;left:0}.toast-container-top-center{top:0;left:50%;transform:translate(-50%)}.toast-container-bottom-center{bottom:0;left:50%;transform:translate(-50%)}@media (max-width: 640px){.toast-container{left:0;right:0;transform:none}.alert-toast{min-width:auto;max-width:none;width:100%}}.alert-with-progress{position:relative;overflow:hidden}.alert-progress{position:absolute;bottom:0;left:0;height:3px;background-color:currentColor;opacity:.3;transition:width linear}@keyframes alert-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes alert-slide-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.alert-exiting{animation:alert-slide-out var(--transition-fast) ease-in forwards}@keyframes toast-slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toast-slide-in-left{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}.toast-container-top-right .alert-toast,.toast-container-bottom-right .alert-toast{animation:toast-slide-in-right var(--transition-normal) ease-out}.toast-container-top-left .alert-toast,.toast-container-bottom-left .alert-toast{animation:toast-slide-in-left var(--transition-normal) ease-out}.chat-container{display:flex;flex-direction:column;height:100%;max-width:var(--chat-max-width);margin:0 auto}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-4);-webkit-overflow-scrolling:touch}.chat-bubble{max-width:85%;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--chat-bubble-radius);line-height:var(--line-height-relaxed);font-size:var(--font-size-base);animation:chat-bubble-in var(--transition-normal) ease-out}.chat-bubble-user{align-self:flex-end;background:var(--color-primary-gradient);color:var(--color-white);border-bottom-right-radius:var(--radius-md)}.chat-bubble-assistant{align-self:flex-start;background-color:var(--chat-bubble-assistant);color:var(--color-gray-900);border-bottom-left-radius:var(--radius-md);border:1px solid var(--color-gray-200)}.chat-bubble-system{align-self:center;max-width:90%;background-color:var(--color-gray-50);color:var(--color-gray-600);font-size:var(--font-size-sm);text-align:center;border-radius:var(--radius-lg);padding:var(--spacing-2) var(--spacing-4)}.chat-message{display:flex;gap:var(--spacing-3);align-items:flex-end}.chat-message-user{flex-direction:row-reverse}.chat-avatar{width:36px;height:36px;border-radius:var(--radius-full);overflow:hidden;flex-shrink:0}.chat-avatar img{width:100%;height:100%;object-fit:cover}.chat-avatar-ai{background:var(--color-primary-gradient);display:flex;align-items:center;justify-content:center;color:var(--color-white)}.chat-bubble-meta{display:flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-1);font-size:var(--font-size-xs);color:var(--color-gray-400)}.chat-bubble-user .chat-bubble-meta{justify-content:flex-end}.chat-bubble-time{opacity:.8}.chat-bubble-status{display:flex;align-items:center;gap:var(--spacing-1)}.chat-input-container{padding:var(--spacing-4);background-color:var(--color-white);border-top:1px solid var(--color-gray-100)}.chat-input-wrapper{display:flex;align-items:flex-end;gap:var(--spacing-3);background-color:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-2xl);padding:var(--spacing-2) var(--spacing-3);transition:all var(--transition-fast)}.chat-input-wrapper:focus-within{background-color:var(--color-white);border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a5f1a}.chat-input{flex:1;border:none;background:transparent;font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-gray-900);resize:none;min-height:24px;max-height:120px;padding:var(--spacing-1) 0}.chat-input::placeholder{color:var(--color-gray-400)}.chat-input:focus{outline:none}.chat-input-actions{display:flex;align-items:center;gap:var(--spacing-1)}.chat-input-action{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:none;color:var(--color-gray-400);cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-fast)}.chat-input-action:hover{color:var(--color-gray-600);background-color:var(--color-gray-200)}.chat-input-send{background:var(--color-primary-gradient);color:var(--color-white)}.chat-input-send:hover{opacity:.9;color:var(--color-white);background:var(--color-primary-gradient)}.chat-input-send:disabled{opacity:.5;cursor:not-allowed}.suggestions-container{padding:var(--spacing-3) var(--spacing-4);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.suggestions-container::-webkit-scrollbar{display:none}.suggestions-list{display:flex;gap:var(--spacing-2);flex-wrap:nowrap}.suggestion-chip{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);background-color:var(--suggestion-bg);border:1px solid var(--suggestion-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700);white-space:nowrap;cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.suggestion-chip:hover{background-color:var(--suggestion-hover);border-color:var(--color-gray-300)}.suggestion-chip:active{background-color:#1e3a5f1a;border-color:var(--color-primary);color:var(--color-primary)}.suggestion-chip-icon{width:16px;height:16px;color:var(--color-gray-400)}.suggestion-chip-featured{background:linear-gradient(135deg,#1e3a5f0d,#1e3a5f1a);border-color:var(--color-primary-lighter);color:var(--color-primary)}.suggestion-chip-featured .suggestion-chip-icon{color:var(--color-primary)}.ai-thinking{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4)}.ai-thinking-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-primary-gradient);display:flex;align-items:center;justify-content:center;color:var(--color-white);animation:ai-pulse 2s ease-in-out infinite}.ai-thinking-content{display:flex;align-items:center;gap:var(--spacing-2)}.ai-thinking-text{font-size:var(--font-size-sm);color:var(--color-gray-500)}.ai-glow{box-shadow:var(--ai-glow)}.quick-actions{padding:var(--spacing-4);background-color:var(--color-gray-50);border-radius:var(--radius-xl)}.quick-actions-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);margin-bottom:var(--spacing-3)}.quick-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-2)}@media (min-width: 640px){.quick-actions-grid{grid-template-columns:repeat(4,1fr)}}.quick-action-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2);padding:var(--spacing-4);background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:center}.quick-action-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.quick-action-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#1e3a5f14;border-radius:var(--radius-lg);color:var(--color-primary)}.quick-action-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.help-card{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:var(--color-white);border-radius:var(--radius-xl);padding:var(--spacing-5);position:relative;overflow:hidden}.help-card:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 60%);pointer-events:none}.help-card-icon{width:48px;height:48px;background:#fff3;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-4)}.help-card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-2)}.help-card-text{font-size:var(--font-size-sm);opacity:.9;line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-4)}.help-card-action{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);background-color:var(--color-white);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-decoration:none;transition:all var(--transition-fast)}.help-card-action:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.smart-search{position:relative}.smart-search-input{width:100%;padding:var(--spacing-4) var(--spacing-5);padding-left:calc(var(--spacing-5) + 24px);font-size:var(--font-size-lg);border:2px solid var(--color-gray-200);border-radius:var(--radius-2xl);background-color:var(--color-white);transition:all var(--transition-fast)}.smart-search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-lg),0 0 0 4px #1e3a5f1a}.smart-search-icon{position:absolute;left:var(--spacing-5);top:50%;transform:translateY(-50%);width:24px;height:24px;color:var(--color-gray-400)}.smart-search-results{position:absolute;top:calc(100% + var(--spacing-2));left:0;right:0;background-color:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);border:1px solid var(--color-gray-100);max-height:400px;overflow-y:auto;z-index:var(--z-dropdown)}.smart-search-result{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);cursor:pointer;transition:background-color var(--transition-fast)}.smart-search-result:hover{background-color:var(--color-gray-50)}.smart-search-result-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:var(--color-gray-100);border-radius:var(--radius-lg);color:var(--color-gray-500)}.smart-search-result-content{flex:1}.smart-search-result-title{font-weight:var(--font-weight-medium);color:var(--color-gray-900)}.smart-search-result-subtitle{font-size:var(--font-size-sm);color:var(--color-gray-500)}@keyframes chat-bubble-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes ai-pulse{0%,to{box-shadow:0 0 #1e3a5f66}50%{box-shadow:0 0 0 12px #1e3a5f00}}@media (max-width: 640px){.chat-messages{padding:var(--spacing-3)}.chat-bubble{max-width:90%;padding:var(--spacing-3)}.chat-input-container{padding:var(--spacing-3);padding-bottom:calc(var(--spacing-3) + var(--bottom-nav-safe-area))}.suggestions-container{padding:var(--spacing-2) var(--spacing-3)}.smart-search-input{font-size:var(--font-size-base);padding:var(--spacing-3) var(--spacing-4);padding-left:calc(var(--spacing-4) + 20px)}}.public-layout{min-height:100vh;display:flex;flex-direction:column}.public-header{padding:var(--spacing-4);text-align:center;border-bottom:1px solid var(--color-gray-200)}.logo{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);text-decoration:none}.public-main{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-4);background:var(--color-gray-50)}.auth-logo{text-align:center;margin-bottom:var(--spacing-6)}.auth-logo img{height:56px;width:auto}.app-layout{display:flex;flex-direction:column;min-height:100vh}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);background:var(--color-white);border-bottom:1px solid var(--color-gray-200);position:sticky;top:0;z-index:100}.mobile-logo{height:32px;width:auto}.menu-toggle{background:none;border:none;padding:var(--spacing-2);cursor:pointer;font-size:1.5rem;color:var(--color-gray-700)}.mobile-menu-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;opacity:0;transition:opacity .3s ease}.mobile-menu-overlay.open{display:block;opacity:1}.mobile-menu{position:fixed;top:0;right:-280px;width:280px;height:100vh;background:var(--color-white);z-index:300;display:flex;flex-direction:column;transition:right .3s ease;box-shadow:var(--shadow-xl)}.mobile-menu.open{right:0}.mobile-menu-header{padding:var(--spacing-6) var(--spacing-4);background:var(--color-gray-900);color:var(--color-white)}.mobile-menu-header .user-info{margin-bottom:0}.mobile-menu-header .user-name{color:var(--color-white)}.mobile-menu-nav{flex:1;padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-1);overflow-y:auto}.mobile-nav-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);color:var(--color-gray-700);text-decoration:none;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.mobile-nav-item:hover{background:var(--color-gray-100);text-decoration:none}.mobile-nav-item.active{background:var(--color-primary-light);color:var(--color-primary)}.mobile-menu-footer{padding:var(--spacing-4);border-top:1px solid var(--color-gray-200)}.mobile-bottom-nav{display:flex;justify-content:space-around;align-items:center;position:fixed;bottom:0;left:0;right:0;background:var(--color-white);border-top:1px solid var(--color-gray-200);padding:var(--spacing-2) 0;padding-bottom:calc(var(--spacing-2) + env(safe-area-inset-bottom));z-index:100}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1);padding:var(--spacing-2) var(--spacing-3);color:var(--color-gray-500);text-decoration:none;font-size:var(--font-size-xs);transition:color var(--transition-fast)}.bottom-nav-item .nav-icon{font-size:1.25rem}.bottom-nav-item .nav-label{font-weight:500}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-item:hover{text-decoration:none}.sidebar{display:none}.main-content{flex:1;background:var(--color-gray-50);padding-bottom:80px;margin-top:0}@media (min-width: 769px){.mobile-header,.mobile-menu-overlay,.mobile-menu,.mobile-bottom-nav{display:none!important}.app-layout{flex-direction:row}.sidebar{width:250px;background:var(--color-gray-900);color:var(--color-white);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0}.sidebar-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-gray-800);text-align:center}.sidebar-header .logo-img{height:44px;width:auto}.sidebar-nav{flex:1;padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-1)}.nav-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);color:var(--color-gray-400);text-decoration:none;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.nav-item:hover{background:var(--color-gray-800);color:var(--color-white);text-decoration:none}.nav-item.active{background:var(--color-primary);color:var(--color-white)}.nav-icon{font-size:1.2em}.sidebar-footer{padding:var(--spacing-4);border-top:1px solid var(--color-gray-800)}.user-info{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-3)}.user-avatar{width:36px;height:36px;background:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600}.user-name{font-weight:500;color:var(--color-gray-300)}.main-content{margin-left:250px;padding-bottom:0;min-height:100vh}.public-main{padding:var(--spacing-8)}.auth-logo img{height:72px}}.ios-install-prompt{position:fixed;bottom:80px;left:var(--spacing-4);right:var(--spacing-4);z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.ios-install-content{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:var(--color-white);border-radius:var(--radius-xl);box-shadow:0 4px 20px #00000026;border:1px solid var(--color-gray-200)}.ios-install-icon{width:40px;height:40px;border-radius:var(--radius-lg);flex-shrink:0}.ios-install-text{flex:1;display:flex;flex-direction:column;gap:2px;font-size:var(--font-size-sm);line-height:1.3}.ios-install-text strong{color:var(--color-gray-900)}.ios-install-text span{color:var(--color-gray-600);display:flex;align-items:center;gap:4px;flex-wrap:wrap}.ios-share-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--color-primary)}.ios-install-close{background:none;border:none;font-size:1.5rem;color:var(--color-gray-400);cursor:pointer;padding:var(--spacing-1);line-height:1;flex-shrink:0}.ios-install-close:hover{color:var(--color-gray-600)}@media (min-width: 769px){.ios-install-prompt{display:none}}:root{--color-primary: #1E3A5F;--color-primary-light: #2E5A8F;--color-primary-lighter: #4A7AB8;--color-primary-dark: #0F1F33;--color-primary-gradient: linear-gradient(135deg, #1E3A5F 0%, #2E5A8F 100%);--color-accent: #FF6B35;--color-accent-light: #FF8F66;--color-accent-dark: #E54E1A;--color-accent-gradient: linear-gradient(135deg, #FF6B35 0%, #FF8F66 100%);--color-secondary: #64748B;--color-secondary-light: #94A3B8;--color-secondary-dark: #475569;--color-white: #FFFFFF;--color-gray-25: #FAFBFC;--color-gray-50: #F8FAFC;--color-gray-100: #F1F5F9;--color-gray-200: #E2E8F0;--color-gray-300: #CBD5E1;--color-gray-400: #94A3B8;--color-gray-500: #64748B;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1E293B;--color-gray-900: #0F172A;--color-black: #000000;--color-success: #10B981;--color-success-light: #D1FAE5;--color-success-dark: #059669;--color-warning: #F59E0B;--color-warning-light: #FEF3C7;--color-warning-dark: #D97706;--color-error: #EF4444;--color-error-light: #FEE2E2;--color-error-dark: #DC2626;--color-info: #3B82F6;--color-info-light: #DBEAFE;--color-info-dark: #2563EB;--color-bg-primary: #FFFFFF;--color-bg-secondary: #F8FAFC;--color-bg-tertiary: #F1F5F9;--color-bg-dark: #0F172A;--color-bg-overlay: rgba(15, 23, 42, .6);--color-bg-glass: rgba(255, 255, 255, .85);--color-bg-glass-dark: rgba(15, 23, 42, .85);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, sans-serif;--font-family-heading: "Inter", -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto, sans-serif;--font-family-mono: "SF Mono", "Fira Code", "JetBrains Mono", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .025em;--spacing-0: 0;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--spacing-20: 5rem;--spacing-24: 6rem;--touch-target-min: 44px;--touch-target-comfortable: 48px;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-3xl: 2rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -2px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--shadow-inner: inset 0 2px 4px rgba(0, 0, 0, .04);--shadow-primary: 0 4px 14px rgba(30, 58, 95, .25);--shadow-accent: 0 4px 14px rgba(255, 107, 53, .25);--shadow-success: 0 4px 14px rgba(16, 185, 129, .25);--shadow-error: 0 4px 14px rgba(239, 68, 68, .25);--glass-bg: rgba(255, 255, 255, .7);--glass-blur: blur(20px);--glass-border: 1px solid rgba(255, 255, 255, .3);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .08);--border-width: 1px;--border-color: var(--color-gray-200);--border-color-light: var(--color-gray-100);--border-color-dark: var(--color-gray-300);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--animation-fade-in: fadeIn .3s ease-out;--animation-slide-up: slideUp .3s ease-out;--animation-slide-down: slideDown .3s ease-out;--animation-scale-in: scaleIn .2s ease-out;--animation-bounce: bounce .5s ease-out;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800;--z-chat: 900;--z-max: 9999;--chat-bubble-user: var(--color-primary);--chat-bubble-assistant: var(--color-gray-100);--chat-bubble-radius: var(--radius-2xl);--chat-input-height: 56px;--chat-max-width: 680px;--suggestion-bg: var(--color-white);--suggestion-border: var(--color-gray-200);--suggestion-hover: var(--color-gray-50);--suggestion-active: var(--color-primary-light);--ai-glow: 0 0 20px rgba(59, 130, 246, .3);--ai-pulse-color: var(--color-info);--fab-size: 56px;--fab-size-sm: 48px;--fab-shadow: 0 6px 16px rgba(0, 0, 0, .15);--bottom-nav-height: 64px;--bottom-nav-safe-area: env(safe-area-inset-bottom, 0px);--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1200px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes typing{0%,60%,to{opacity:.3}30%{opacity:1}}@media (prefers-color-scheme: dark){:root{--color-bg-primary: #0F172A;--color-bg-secondary: #1E293B;--color-bg-tertiary: #334155;--border-color: var(--color-gray-700);--border-color-light: var(--color-gray-800);--glass-bg: rgba(15, 23, 42, .7)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-gray-900);background-color:var(--color-bg-secondary);min-height:100vh;overflow-x:hidden}body{padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0);padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0)}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);color:var(--color-gray-900)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-base)}h6{font-size:var(--font-size-sm)}@media (min-width: 768px){h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}}p{margin-bottom:var(--spacing-4);color:var(--color-gray-600)}p:last-child{margin-bottom:0}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-muted{color:var(--color-gray-500)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover,a:focus{color:var(--color-primary-dark);text-decoration:underline}a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}button,input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit}button{cursor:pointer;border:none;background:none}button:disabled{cursor:not-allowed;opacity:.6}input,textarea,select{min-height:var(--touch-target-min)}input[type=checkbox],input[type=radio]{min-height:auto;width:20px;height:20px}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}:focus{outline:none}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background-color:var(--color-primary);color:var(--color-white)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}@media (max-width: 768px){::-webkit-scrollbar{display:none}*{scrollbar-width:none}}.container{width:100%;max-width:var(--container-xl);margin:0 auto;padding:0 var(--spacing-4)}@media (min-width: 768px){.container{padding:0 var(--spacing-6)}}.flex{display:flex}.inline-flex{display:inline-flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-auto{flex:auto}.flex-none{flex:none}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.md\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.md\:grid-cols-4{grid-template-columns:repeat(4,1fr)}}.gap-1{gap:var(--spacing-1)}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.gap-5{gap:var(--spacing-5)}.gap-6{gap:var(--spacing-6)}.gap-8{gap:var(--spacing-8)}.p-0{padding:0}.p-1{padding:var(--spacing-1)}.p-2{padding:var(--spacing-2)}.p-3{padding:var(--spacing-3)}.p-4{padding:var(--spacing-4)}.p-5{padding:var(--spacing-5)}.p-6{padding:var(--spacing-6)}.p-8{padding:var(--spacing-8)}.px-4{padding-left:var(--spacing-4);padding-right:var(--spacing-4)}.py-4{padding-top:var(--spacing-4);padding-bottom:var(--spacing-4)}.px-6{padding-left:var(--spacing-6);padding-right:var(--spacing-6)}.py-6{padding-top:var(--spacing-6);padding-bottom:var(--spacing-6)}.m-0{margin:0}.m-auto{margin:auto}.mx-auto{margin-left:auto;margin-right:auto}.my-4{margin-top:var(--spacing-4);margin-bottom:var(--spacing-4)}.mb-2{margin-bottom:var(--spacing-2)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.bg-white{background-color:var(--color-white)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-primary{background-color:var(--color-primary)}.bg-primary-light{background-color:var(--color-primary-light)}.border{border:1px solid var(--border-color)}.border-0{border:none}.border-t{border-top:1px solid var(--border-color)}.border-b{border-bottom:1px solid var(--border-color)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.invisible{visibility:hidden}.visible{visibility:visible}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-100{opacity:1}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.transition{transition:all var(--transition-normal)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}.hide-mobile{display:none!important}@media (min-width: 768px){.hide-mobile{display:block!important}.hide-desktop{display:none!important}}.show-mobile{display:block}@media (min-width: 768px){.show-mobile{display:none}}.animate-fade-in{animation:var(--animation-fade-in)}.animate-slide-up{animation:var(--animation-slide-up)}.animate-scale-in{animation:var(--animation-scale-in)}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.card{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border-color-light);overflow:hidden}.card-elevated{box-shadow:var(--shadow-lg);border:none}.glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow)}.page{min-height:100vh;padding:var(--spacing-4);padding-bottom:calc(var(--bottom-nav-height) + var(--bottom-nav-safe-area) + var(--spacing-4))}@media (min-width: 768px){.page{padding:var(--spacing-6);padding-bottom:var(--spacing-6)}}.page-header{margin-bottom:var(--spacing-6)}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-2)}@media (min-width: 768px){.page-title{font-size:var(--font-size-3xl)}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);padding-bottom:var(--bottom-nav-safe-area);background:var(--color-white);border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-around;z-index:var(--z-fixed)}@media (min-width: 768px){.bottom-nav{display:none}}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2);color:var(--color-gray-500);text-decoration:none;transition:color var(--transition-fast);min-width:64px;min-height:var(--touch-target-min)}.bottom-nav-item.active,.bottom-nav-item:hover{color:var(--color-primary)}.bottom-nav-icon{font-size:24px;margin-bottom:2px}.bottom-nav-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.skeleton{background:linear-gradient(90deg,var(--color-gray-200) 25%,var(--color-gray-100) 50%,var(--color-gray-200) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-text{height:1em;margin-bottom:.5em}.skeleton-avatar{width:48px;height:48px;border-radius:var(--radius-full)}.skeleton-card{height:200px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12) var(--spacing-4);text-align:center}.empty-state-icon{font-size:64px;margin-bottom:var(--spacing-4);opacity:.5}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);margin-bottom:var(--spacing-2)}.empty-state-description{font-size:var(--font-size-sm);color:var(--color-gray-500);max-width:300px}.badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-error{background:var(--color-error-light);color:var(--color-error-dark)}.badge-info{background:var(--color-info-light);color:var(--color-info-dark)}.badge-neutral{background:var(--color-gray-100);color:var(--color-gray-600)}.avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-primary-gradient);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-sm{width:32px;height:32px;font-size:var(--font-size-xs)}.avatar-lg{width:56px;height:56px;font-size:var(--font-size-lg)}.avatar-xl{width:80px;height:80px;font-size:var(--font-size-2xl)}.divider{height:1px;background:var(--border-color);margin:var(--spacing-4) 0}.divider-vertical{width:1px;height:100%;background:var(--border-color);margin:0 var(--spacing-4)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media print{.no-print{display:none!important}body{background:#fff}.page{padding:0}}.auth-card{width:100%;max-width:420px;padding:var(--spacing-6);background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.auth-title{font-size:var(--font-size-xl);text-align:center;margin-bottom:var(--spacing-2)}.auth-subtitle{text-align:center;color:var(--color-gray-600);margin-bottom:var(--spacing-6)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.auth-footer{text-align:center;margin-top:var(--spacing-6);color:var(--color-gray-600)}@media (min-width: 769px){.auth-card{padding:var(--spacing-8)}.auth-title{font-size:var(--font-size-2xl)}}.page{padding:var(--spacing-4)}.page-title{font-size:var(--font-size-xl);margin-bottom:var(--spacing-4)}.page-header-row{display:flex;flex-direction:column;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}@media (min-width: 769px){.page{padding:var(--spacing-8)}.page-title{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-6)}.page-header-row{flex-direction:row;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6)}}.dashboard-hero{background:var(--color-primary-gradient);border-radius:var(--radius-2xl);padding:var(--spacing-6);margin-bottom:var(--spacing-6);color:var(--color-white)}.dashboard-hero h1{color:var(--color-white);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-1)}.dashboard-hero p{color:#fffc;margin-bottom:var(--spacing-4)}.hero-actions{display:flex;gap:var(--spacing-3)}@media (min-width: 769px){.dashboard-hero{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-8)}.dashboard-hero h1{font-size:var(--font-size-3xl)}.dashboard-hero p{margin-bottom:0}}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-3);margin-bottom:var(--spacing-6)}.stat-card{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border-left:4px solid var(--color-primary)}.stat-card.stat-pending{border-left-color:var(--color-warning)}.stat-card.stat-completed{border-left-color:var(--color-success)}.stat-card.stat-reviews{border-left-color:var(--color-primary)}.stat-card.stat-rating{border-left-color:var(--color-accent)}.stat-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-gray-50);border-radius:var(--radius-lg)}.stat-content{flex:1}.stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-900);line-height:1}.stat-label{color:var(--color-gray-600);margin-top:var(--spacing-1);font-size:var(--font-size-sm)}.ai-assistant-section{background:linear-gradient(135deg,#f0f7ff,#e8f4fd);border-radius:var(--radius-2xl);padding:var(--spacing-6);margin-bottom:var(--spacing-6);border:1px solid var(--color-primary-light)}.ai-suggestion{margin-top:var(--spacing-4)}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.activity-card{background:var(--color-white);border-radius:var(--radius-xl)}.recent-item{display:flex;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-lg);transition:background var(--transition-fast)}.recent-item:hover{background:var(--color-gray-100)}.recent-item-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-primary);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-base);flex-shrink:0}.recent-item-content{flex:1;min-width:0}.rating-stars{color:var(--color-accent);font-size:var(--font-size-sm)}.review-preview{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.empty-state-mini{text-align:center;padding:var(--spacing-6);color:var(--color-gray-500)}.empty-state-mini .empty-icon{font-size:2.5rem;margin-bottom:var(--spacing-2);display:block}.empty-state-mini p{font-weight:500;color:var(--color-gray-700);margin-bottom:var(--spacing-1)}.empty-state-mini .empty-hint{font-size:var(--font-size-sm)}.tips-card{background:var(--color-white);border-radius:var(--radius-xl)}.tips-card h3{margin-bottom:var(--spacing-4);font-size:var(--font-size-lg)}.tip-item{display:flex;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-lg)}.tip-icon{font-size:1.5rem;flex-shrink:0}.tip-item strong{display:block;color:var(--color-gray-900);margin-bottom:var(--spacing-1)}.tip-item p{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:0}@media (min-width: 769px){.stats-grid{grid-template-columns:repeat(4,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-8)}.stat-card{padding:var(--spacing-5)}.stat-icon{font-size:1.75rem;width:56px;height:56px}.stat-value{font-size:var(--font-size-3xl)}.stat-label{font-size:var(--font-size-base);margin-top:var(--spacing-1)}.dashboard-grid{grid-template-columns:1fr 1fr;gap:var(--spacing-6)}.tips-grid{grid-template-columns:repeat(3,1fr)}}.card-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.card-header-row h3{margin:0;font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-900)}.view-all-link{font-size:var(--font-size-sm);color:var(--color-primary);text-decoration:none;font-weight:500}.view-all-link:hover{text-decoration:underline}.recent-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.recent-item-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-1)}.recent-item-title{font-weight:500;color:var(--color-gray-900)}.recent-item-sub{font-size:var(--font-size-sm);color:var(--color-gray-600)}.rating-badge{color:var(--color-accent);font-size:var(--font-size-sm)}.form-grid{display:flex;flex-direction:column;gap:var(--spacing-4);max-width:500px}.portfolio-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-4)}.portfolio-card{overflow:hidden}.portfolio-media{position:relative;aspect-ratio:16/10;background:var(--color-gray-100);overflow:hidden}.portfolio-media img,.portfolio-media video{width:100%;height:100%;object-fit:cover}.featured-badge{position:absolute;top:var(--spacing-2);left:var(--spacing-2);background:var(--color-accent);color:var(--color-white);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:600}.video-badge{position:absolute;bottom:var(--spacing-2);right:var(--spacing-2);background:#000000b3;color:var(--color-white);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);font-size:var(--font-size-xs)}.portfolio-details{padding:var(--spacing-4)}.portfolio-title{font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--spacing-1);color:var(--color-gray-900)}.portfolio-type{display:inline-block;background:var(--color-gray-100);color:var(--color-gray-600);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);font-size:var(--font-size-xs);text-transform:capitalize;margin-bottom:var(--spacing-2)}.portfolio-description{font-size:var(--font-size-sm);color:var(--color-gray-600);line-height:1.5;margin-bottom:var(--spacing-3);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.portfolio-actions{display:flex;gap:var(--spacing-1);flex-wrap:wrap;border-top:1px solid var(--color-gray-100);padding-top:var(--spacing-3);margin-top:var(--spacing-2)}.portfolio-actions button{font-size:var(--font-size-sm)}@media (min-width: 769px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}}.upload-toggle{display:flex;background:var(--color-gray-100);border-radius:var(--radius-lg);padding:var(--spacing-1);margin-bottom:var(--spacing-4)}.toggle-btn{flex:1;padding:var(--spacing-2) var(--spacing-4);border:none;background:transparent;border-radius:var(--radius-md);font-weight:500;color:var(--color-gray-600);cursor:pointer;transition:all var(--transition-fast)}.toggle-btn.active{background:var(--color-white);color:var(--color-primary);box-shadow:var(--shadow-sm)}.url-input-area{margin-bottom:var(--spacing-4)}.url-preview{margin-top:var(--spacing-3);text-align:center}.url-preview img{max-height:150px;border-radius:var(--radius-lg)}.url-hint{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-top:var(--spacing-2)}.upload-area{border:2px dashed var(--color-gray-300);border-radius:var(--radius-xl);padding:var(--spacing-8);text-align:center;cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--spacing-4);background:var(--color-gray-50)}.upload-area:hover{border-color:var(--color-primary);background:var(--color-gray-100)}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2)}.upload-icon{font-size:3rem}.upload-placeholder p{font-weight:500;color:var(--color-gray-700);margin:0}.upload-hint{font-size:var(--font-size-sm);color:var(--color-gray-500)}.upload-preview{position:relative}.upload-preview img,.upload-preview video{max-height:200px;border-radius:var(--radius-lg);margin:0 auto}.change-file-btn{margin-top:var(--spacing-2)}.edit-preview{margin-bottom:var(--spacing-4);text-align:center}.edit-preview img,.edit-preview video{max-height:150px;border-radius:var(--radius-lg)}.modal-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.modal-actions{display:flex;gap:var(--spacing-3);justify-content:flex-end;margin-top:var(--spacing-2)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-2);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-gray-700)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-4)}.loading-container{display:flex;justify-content:center;padding:var(--spacing-12)}.filter-tabs{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-6)}.filter-tab{padding:var(--spacing-2) var(--spacing-4);background:var(--color-gray-100);border:none;border-radius:var(--radius-lg);cursor:pointer}.filter-tab.active{background:var(--color-primary);color:var(--color-white)}.visits-list{display:flex;flex-direction:column;gap:var(--spacing-4)}.visit-card{padding:var(--spacing-4)}.visit-header{display:flex;justify-content:space-between;margin-bottom:var(--spacing-3)}.status-badge{padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase}.status-pending{background:var(--color-warning-light);color:#92400e}.status-accepted{background:#d1fae5;color:#065f46}.status-completed{background:#dbeafe;color:#1e40af}.status-declined{background:#fee2e2;color:#991b1b}.visit-actions{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-4)}.reviews-list{display:flex;flex-direction:column;gap:var(--spacing-4)}.review-card{padding:var(--spacing-4)}.review-header{display:flex;justify-content:space-between;margin-bottom:var(--spacing-3)}.review-text{color:var(--color-gray-700);line-height:1.6}.reviewer-name{color:var(--color-gray-500);font-size:var(--font-size-sm);margin-top:var(--spacing-2)}.response-box{margin-top:var(--spacing-4);padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-md)}.respond-form{margin-top:var(--spacing-4)}.respond-actions{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-2)}.current-plan{margin-bottom:var(--spacing-6);border-left:4px solid var(--color-primary);padding:var(--spacing-4);background:var(--color-white);border-radius:var(--radius-lg)}.section-title{font-size:var(--font-size-lg);margin-bottom:var(--spacing-4)}.plans-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-4)}.plan-card{text-align:center;position:relative;padding:var(--spacing-6);background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.plan-card.featured{border:2px solid var(--color-primary);box-shadow:var(--shadow-primary)}.plan-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--color-primary);color:var(--color-white);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.plan-price{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary);margin:var(--spacing-4) 0}.plan-price span{font-size:var(--font-size-sm);color:var(--color-gray-500)}.plan-savings{color:var(--color-success);font-weight:600;font-size:var(--font-size-sm)}.plan-features{list-style:none;padding:0;margin:var(--spacing-4) 0;text-align:left}.plan-features li{padding:var(--spacing-2) 0;color:var(--color-gray-600);font-size:var(--font-size-sm)}.plan-features li:before{content:"✓ ";color:var(--color-success)}.empty-state{text-align:center;padding:var(--spacing-8) var(--spacing-4)}.empty-text{color:var(--color-gray-500);margin-top:var(--spacing-4)}.status-active{color:var(--color-success);font-weight:600}@media (min-width: 769px){.current-plan{margin-bottom:var(--spacing-8);padding:var(--spacing-6)}.section-title{font-size:var(--font-size-xl)}.plans-grid{grid-template-columns:repeat(3,1fr);gap:var(--spacing-6)}.plan-price{font-size:var(--font-size-3xl)}.plan-price span,.plan-savings,.plan-features li{font-size:var(--font-size-base)}}.help-hero{text-align:center;padding:var(--spacing-8) var(--spacing-4);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark, #2563eb));border-radius:var(--radius-xl);color:#fff;margin-bottom:var(--spacing-6)}.ai-avatar-large{font-size:3rem;margin-bottom:var(--spacing-3)}.help-hero h1{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-2);color:#fff}.help-hero p{opacity:.9;font-size:var(--font-size-base)}.suggestions-section{margin-bottom:var(--spacing-6)}.suggestions-section h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-3);color:var(--color-gray-800)}.suggestions-list{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.tips-card{margin-bottom:var(--spacing-6)}.tips-card h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-4);color:var(--color-gray-800)}.tips-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-4)}.tip-item{display:flex;gap:var(--spacing-3);align-items:flex-start}.tip-icon{font-size:1.5rem;line-height:1}.tip-item strong{display:block;margin-bottom:var(--spacing-1);color:var(--color-gray-800)}.tip-item p{margin:0;color:var(--color-gray-600);font-size:var(--font-size-sm)}.faq-section{margin-bottom:var(--spacing-6)}.faq-section h2{font-size:var(--font-size-xl);margin-bottom:var(--spacing-4);color:var(--color-gray-800)}.faq-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.faq-item{border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);overflow:hidden}.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4);background:var(--color-white);border:none;cursor:pointer;text-align:left;font-size:var(--font-size-base);font-weight:500;color:var(--color-gray-800);transition:background-color var(--transition-fast)}.faq-question:hover{background:var(--color-gray-50)}.faq-icon{font-size:1.25rem;color:var(--color-gray-500)}.faq-answer{padding:0 var(--spacing-4) var(--spacing-4);color:var(--color-gray-600);line-height:1.6;background:var(--color-gray-50)}@media (min-width: 769px){.help-hero{padding:var(--spacing-12) var(--spacing-8);margin-bottom:var(--spacing-8)}.ai-avatar-large{font-size:4rem}.help-hero h1{font-size:var(--font-size-3xl)}.tips-grid{grid-template-columns:repeat(2,1fr)}.suggestions-section h3,.tips-card h3{font-size:var(--font-size-xl)}}
