.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}.media-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal, 1000);background:#000;display:flex;flex-direction:column;touch-action:pan-y;-webkit-user-select:none;user-select:none;overscroll-behavior:contain}.media-viewer-header{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4, 1rem);padding-top:calc(var(--spacing-4, 1rem) + env(safe-area-inset-top,0));background:linear-gradient(to bottom,rgba(0,0,0,.7) 0%,transparent 100%);opacity:0;transition:opacity .3s ease;pointer-events:none}.media-viewer-header.visible{opacity:1;pointer-events:auto}.media-viewer-close,.media-viewer-mute{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .2s ease}.media-viewer-close:hover,.media-viewer-mute:hover{background:#fff3}.media-viewer-counter{font-size:var(--font-size-sm, .875rem);font-weight:600;color:#fff;background:#00000080;padding:var(--spacing-1, .25rem) var(--spacing-3, .75rem);border-radius:var(--radius-full, 9999px);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.media-viewer-content{flex:1;position:relative;overflow:hidden}.media-viewer-slides{display:flex;flex-direction:column;height:100%;transition:transform .3s cubic-bezier(.4,0,.2,1)}.media-viewer-slide{flex:0 0 100%;height:100vh;height:100dvh;display:flex;align-items:center;justify-content:center;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);position:relative}.media-viewer-image,.media-viewer-video{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.media-viewer-video{background:#000;cursor:pointer}.media-viewer-play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all .2s ease;z-index:5}.media-viewer-play-btn:hover{background:#000c;transform:translate(-50%,-50%) scale(1.1)}.media-viewer-play-btn svg{margin-left:4px}.media-viewer-progress{position:absolute;right:var(--spacing-3, .75rem);top:50%;transform:translateY(-50%);z-index:10;display:flex;flex-direction:column;gap:var(--spacing-2, .5rem)}.media-viewer-progress-dot{width:6px;height:6px;padding:0;border:none;border-radius:50%;background:#fff6;cursor:pointer;transition:all .2s ease}.media-viewer-progress-dot:hover{background:#fff9;transform:scale(1.3)}.media-viewer-progress-dot.active{background:#fff;height:20px;border-radius:3px}.media-viewer-progress:has(:only-child),.media-viewer-progress:has(:nth-child(21)){display:none}.media-viewer-info{position:absolute;bottom:0;left:0;right:0;z-index:10;padding:var(--spacing-6, 1.5rem);padding-bottom:calc(var(--spacing-6, 1.5rem) + env(safe-area-inset-bottom,0));background:linear-gradient(to top,rgba(0,0,0,.8) 0%,rgba(0,0,0,.4) 50%,transparent 100%);opacity:0;transition:opacity .3s ease;pointer-events:none}.media-viewer-info.visible{opacity:1}.media-viewer-title{color:#fff;font-size:var(--font-size-lg, 1.125rem);font-weight:600;margin:0 0 var(--spacing-2, .5rem) 0;text-shadow:0 1px 2px rgba(0,0,0,.5)}.media-viewer-description{color:#fffc;font-size:var(--font-size-sm, .875rem);line-height:1.5;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.5);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.media-viewer-hints{position:absolute;left:50%;transform:translate(-50%);z-index:10;opacity:0;transition:opacity .3s ease;pointer-events:none}.media-viewer-hints.visible{opacity:1}.media-viewer-hint{position:absolute;left:50%;transform:translate(-50%);color:#fff9;animation:bounce 2s infinite}.hint-up{top:calc(80px + env(safe-area-inset-top,0));animation-name:bounceUp}.hint-down{bottom:calc(80px + env(safe-area-inset-bottom,0));animation-name:bounceDown}@keyframes bounceUp{0%,20%,50%,80%,to{transform:translate(-50%) translateY(0)}40%{transform:translate(-50%) translateY(-10px)}60%{transform:translate(-50%) translateY(-5px)}}@keyframes bounceDown{0%,20%,50%,80%,to{transform:translate(-50%) translateY(0)}40%{transform:translate(-50%) translateY(10px)}60%{transform:translate(-50%) translateY(5px)}}.media-viewer-nav-desktop{display:none}@media (min-width: 769px){.media-viewer-nav-desktop{display:block}.media-viewer-nav-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .2s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.media-viewer-nav-btn:hover{background:#000000b3;transform:translateY(-50%) scale(1.1)}.nav-prev{left:var(--spacing-6, 1.5rem)}.nav-next{right:var(--spacing-6, 1.5rem)}.media-viewer-hints{display:none}.media-viewer-progress{right:auto;left:50%;top:auto;bottom:calc(var(--spacing-6, 1.5rem) + env(safe-area-inset-bottom,0));transform:translate(-50%);flex-direction:row;gap:var(--spacing-2, .5rem)}.media-viewer-progress-dot.active{height:6px;width:20px}}.media-thumbnail{position:relative;overflow:hidden;border-radius:var(--radius-md, .5rem);cursor:pointer;background:var(--gray-100, #f3f4f6);transition:transform .2s ease,box-shadow .2s ease}.media-thumbnail:hover{transform:scale(1.02);box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1))}.media-thumbnail:active{transform:scale(.98)}.media-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.media-thumbnail:hover img{transform:scale(1.05)}.media-thumbnail-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#0009;border-radius:50%;color:#fff;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.media-thumbnail-badge{position:absolute;top:var(--spacing-2, .5rem);left:var(--spacing-2, .5rem);padding:var(--spacing-1, .25rem) var(--spacing-2, .5rem);background:var(--accent, #FF6B35);color:#fff;font-size:var(--font-size-xs, .75rem);font-weight:600;border-radius:var(--radius-sm, .25rem);text-transform:uppercase}.media-grid{width:100%}@media (max-width: 639px){.media-grid{grid-template-columns:repeat(2,1fr)!important}}@media (min-width: 640px) and (max-width: 768px){.media-grid{grid-template-columns:repeat(3,1fr)!important}}.media-viewer-overlay{animation:fadeIn .2s ease}@media (prefers-reduced-motion: reduce){.media-viewer-slides{transition:none}.media-viewer-hint{animation:none}.media-thumbnail,.media-thumbnail img{transition:none}}@media (prefers-contrast: high){.media-viewer-close,.media-viewer-mute,.media-viewer-nav-btn{background:#000;border:2px solid #fff}.media-viewer-progress-dot{border:1px solid #fff}}.doc-annotation{display:flex;flex-direction:column;height:100%;background:var(--color-gray-50, #f9fafb);border-radius:var(--radius-lg, .75rem);overflow:hidden}.doc-annotation-toolbar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3, .75rem) var(--spacing-4, 1rem);background:#fff;border-bottom:1px solid var(--color-gray-200, #e5e7eb)}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:var(--spacing-3, .75rem)}.toolbar-btn{display:flex;align-items:center;gap:var(--spacing-2, .5rem);padding:var(--spacing-2, .5rem) var(--spacing-3, .75rem);background:#fff;border:1px solid var(--color-gray-300, #d1d5db);border-radius:var(--radius-md, .5rem);font-size:var(--font-size-sm, .875rem);font-weight:500;color:var(--color-gray-700, #374151);cursor:pointer;transition:all .2s ease}.toolbar-btn:hover{background:var(--color-gray-50, #f9fafb);border-color:var(--color-primary, #1E3A5F)}.toolbar-btn.active{background:var(--color-primary, #1E3A5F);border-color:var(--color-primary, #1E3A5F);color:#fff}.toolbar-toggle{display:flex;align-items:center;gap:var(--spacing-2, .5rem);font-size:var(--font-size-sm, .875rem);color:var(--color-gray-600, #4b5563);cursor:pointer}.toolbar-toggle input{accent-color:var(--color-primary, #1E3A5F)}.comment-count{font-size:var(--font-size-sm, .875rem);color:var(--color-gray-500, #6b7280);padding:var(--spacing-1, .25rem) var(--spacing-3, .75rem);background:var(--color-gray-100, #f3f4f6);border-radius:var(--radius-full, 9999px)}.doc-annotation-container{position:relative;flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;padding:var(--spacing-4, 1rem);min-height:300px}.doc-annotation-container.adding-pin{cursor:crosshair}.doc-annotation-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-md, .5rem);box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1))}.doc-pin{position:absolute;width:28px;height:28px;transform:translate(-50%,-100%);background:var(--color-primary, #1E3A5F);border:2px solid white;border-radius:50% 50% 50% 0;transform:translate(-50%,-100%) rotate(-45deg);cursor:pointer;box-shadow:0 2px 8px #0003;transition:all .2s ease;z-index:10}.doc-pin:hover{transform:translate(-50%,-100%) rotate(-45deg) scale(1.1);z-index:20}.doc-pin.selected{background:var(--color-accent, #FF6B35);transform:translate(-50%,-100%) rotate(-45deg) scale(1.15);z-index:30}.doc-pin.resolved{background:var(--color-success, #22c55e);opacity:.7}.doc-pin.new-pin{background:var(--color-accent, #FF6B35);animation:pulse 1.5s infinite}.pin-number{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(45deg);font-size:12px;font-weight:600;color:#fff}@keyframes pulse{0%,to{box-shadow:0 2px 8px #ff6b3566}50%{box-shadow:0 2px 16px #ff6b3599}}.doc-comment-panel{position:absolute;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--color-gray-200, #e5e7eb);border-radius:var(--radius-lg, .75rem) var(--radius-lg, .75rem) 0 0;box-shadow:0 -4px 20px #0000001a;max-height:50%;overflow:hidden;display:flex;flex-direction:column;z-index:100;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3, .75rem) var(--spacing-4, 1rem);border-bottom:1px solid var(--color-gray-100, #f3f4f6)}.panel-header h4{margin:0;font-size:var(--font-size-base, 1rem);font-weight:600}.panel-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:50%;color:var(--color-gray-500, #6b7280);cursor:pointer;transition:background .2s ease}.panel-close:hover{background:var(--color-gray-100, #f3f4f6)}.panel-body{flex:1;overflow-y:auto;padding:var(--spacing-4, 1rem)}.comment-input{width:100%;padding:var(--spacing-3, .75rem);border:1px solid var(--color-gray-300, #d1d5db);border-radius:var(--radius-md, .5rem);font-size:var(--font-size-sm, .875rem);resize:none;font-family:inherit}.comment-input:focus{outline:none;border-color:var(--color-primary, #1E3A5F);box-shadow:0 0 0 3px #1e3a5f1a}.panel-actions{display:flex;justify-content:flex-end;gap:var(--spacing-2, .5rem);margin-top:var(--spacing-3, .75rem)}.btn-cancel,.btn-submit{padding:var(--spacing-2, .5rem) var(--spacing-4, 1rem);border-radius:var(--radius-md, .5rem);font-size:var(--font-size-sm, .875rem);font-weight:500;cursor:pointer;transition:all .2s ease}.btn-cancel{background:#fff;border:1px solid var(--color-gray-300, #d1d5db);color:var(--color-gray-700, #374151)}.btn-cancel:hover{background:var(--color-gray-50, #f9fafb)}.btn-submit{background:var(--color-primary, #1E3A5F);border:1px solid var(--color-primary, #1E3A5F);color:#fff}.btn-submit:hover{background:var(--color-primary-dark, #152b47)}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.comment-thread{display:flex;flex-direction:column;gap:var(--spacing-3, .75rem)}.comment-thread.resolved{opacity:.7}.comment-item{padding:var(--spacing-3, .75rem);background:var(--color-gray-50, #f9fafb);border-radius:var(--radius-md, .5rem)}.comment-item.main-comment{background:#fff;border:1px solid var(--color-gray-200, #e5e7eb)}.comment-item.reply{margin-left:var(--spacing-4, 1rem);border-left:2px solid var(--color-primary, #1E3A5F)}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2, .5rem)}.comment-author{font-size:var(--font-size-sm, .875rem);font-weight:600;color:var(--color-gray-800, #1f2937)}.comment-time{font-size:var(--font-size-xs, .75rem);color:var(--color-gray-400, #9ca3af)}.comment-text{font-size:var(--font-size-sm, .875rem);color:var(--color-gray-700, #374151);margin:0;line-height:1.5}.resolve-btn{margin-top:var(--spacing-2, .5rem);padding:var(--spacing-1, .25rem) var(--spacing-2, .5rem);background:none;border:1px solid var(--color-gray-300, #d1d5db);border-radius:var(--radius-sm, .25rem);font-size:var(--font-size-xs, .75rem);color:var(--color-gray-600, #4b5563);cursor:pointer;transition:all .2s ease}.resolve-btn:hover{background:var(--color-gray-100, #f3f4f6)}.resolve-btn.resolved{border-color:var(--color-success, #22c55e);color:var(--color-success, #22c55e)}.reply-input-container{display:flex;gap:var(--spacing-2, .5rem);margin-top:var(--spacing-3, .75rem);padding-top:var(--spacing-3, .75rem);border-top:1px solid var(--color-gray-200, #e5e7eb)}.reply-input{flex:1;padding:var(--spacing-2, .5rem) var(--spacing-3, .75rem);border:1px solid var(--color-gray-300, #d1d5db);border-radius:var(--radius-full, 9999px);font-size:var(--font-size-sm, .875rem)}.reply-input:focus{outline:none;border-color:var(--color-primary, #1E3A5F)}.reply-submit{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--color-primary, #1E3A5F);border:none;border-radius:50%;color:#fff;cursor:pointer;transition:background .2s ease}.reply-submit:hover{background:var(--color-primary-dark, #152b47)}.reply-submit:disabled{background:var(--color-gray-300, #d1d5db);cursor:not-allowed}.doc-annotation-instructions{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:var(--spacing-4, 1rem) var(--spacing-6, 1.5rem);background:#000c;color:#fff;font-size:var(--font-size-sm, .875rem);border-radius:var(--radius-lg, .75rem);z-index:50;pointer-events:none;animation:fadeIn .3s ease}.comments-list-panel{display:flex;flex-direction:column;height:100%;background:#fff;border-left:1px solid var(--color-gray-200, #e5e7eb)}.comments-list-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4, 1rem);border-bottom:1px solid var(--color-gray-200, #e5e7eb)}.comments-list-header h3{margin:0;font-size:var(--font-size-base, 1rem)}.toggle-resolved{display:flex;align-items:center;gap:var(--spacing-2, .5rem);font-size:var(--font-size-xs, .75rem);color:var(--color-gray-500, #6b7280);cursor:pointer}.comments-list-body{flex:1;overflow-y:auto}.no-comments{padding:var(--spacing-8, 2rem);text-align:center;color:var(--color-gray-400, #9ca3af)}.comments-list-item{padding:var(--spacing-3, .75rem) var(--spacing-4, 1rem);border-bottom:1px solid var(--color-gray-100, #f3f4f6);cursor:pointer;transition:background .2s ease}.comments-list-item:hover{background:var(--color-gray-50, #f9fafb)}.comments-list-item.selected{background:var(--color-primary-light, #e8f4ff);border-left:3px solid var(--color-primary, #1E3A5F)}.comments-list-item.resolved{opacity:.6}.item-header{display:flex;align-items:center;gap:var(--spacing-2, .5rem);margin-bottom:var(--spacing-1, .25rem)}.item-number{font-size:var(--font-size-xs, .75rem);font-weight:600;color:var(--color-primary, #1E3A5F)}.item-author{font-size:var(--font-size-sm, .875rem);font-weight:500}.resolved-badge{font-size:var(--font-size-xs, .75rem);padding:2px 6px;background:var(--color-success-light, #dcfce7);color:var(--color-success, #22c55e);border-radius:var(--radius-sm, .25rem)}.item-text{font-size:var(--font-size-sm, .875rem);color:var(--color-gray-600, #4b5563);margin:0 0 var(--spacing-2, .5rem) 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.item-footer{display:flex;justify-content:space-between;font-size:var(--font-size-xs, .75rem);color:var(--color-gray-400, #9ca3af)}@media (min-width: 769px){.doc-comment-panel{position:absolute;right:var(--spacing-4, 1rem);bottom:var(--spacing-4, 1rem);left:auto;width:360px;max-height:calc(100% - var(--spacing-8, 2rem));border-radius:var(--radius-lg, .75rem);border:1px solid var(--color-gray-200, #e5e7eb)}}@media (max-width: 640px){.doc-annotation-toolbar{flex-direction:column;gap:var(--spacing-2, .5rem)}.toolbar-left,.toolbar-right{width:100%;justify-content:space-between}.toolbar-btn{flex:1;justify-content:center}.doc-pin{width:24px;height:24px}.pin-number{font-size:10px}}.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{text-decoration:none;display:flex;align-items:center}.logo img{height:32px;width:auto}.auth-logo{text-align:center;margin-bottom:var(--spacing-6)}.auth-logo img{height:56px;width:auto}.public-main{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-4)}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:var(--color-white);border-bottom:1px solid var(--color-gray-200);position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 var(--spacing-4)}.mobile-menu-toggle{display:block;background:none;border:none;font-size:1.5rem;padding:var(--spacing-2);cursor:pointer;color:var(--color-gray-700)}.desktop-nav,.desktop-actions{display:none}.mobile-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-overlay.open{display:block;opacity:1}.mobile-slide-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-slide-menu.open{right:0}.mobile-menu-user{padding:var(--spacing-6) var(--spacing-4);background:var(--color-primary);color:var(--color-white);display:flex;align-items:center;gap:var(--spacing-3)}.mobile-menu-user .user-avatar.large{width:48px;height:48px;font-size:var(--font-size-lg);background:#fff3}.mobile-menu-user .user-name{font-weight:600;font-size:var(--font-size-lg)}.mobile-nav{flex:1;padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-1)}.mobile-nav-link{display:block;padding:var(--spacing-3) var(--spacing-4);color:var(--color-gray-700);text-decoration:none;border-radius:var(--radius-lg);font-weight:500;transition:background var(--transition-fast)}.mobile-nav-link:hover{background:var(--color-gray-100);text-decoration:none}.mobile-nav-link.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:2px;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}.user-avatar{width:32px;height:32px;background-color:var(--color-primary);color:var(--color-white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-sm)}.user-name{font-weight:500}.app-main{flex:1;background-color:var(--color-gray-50);padding-bottom:80px}@media (min-width: 769px){.mobile-menu-toggle,.mobile-overlay,.mobile-slide-menu,.mobile-bottom-nav{display:none!important}.desktop-nav,.desktop-actions{display:flex}.header-content{height:72px;max-width:1200px;margin:0 auto;padding:0 var(--spacing-6)}.logo img{height:44px}.app-nav{gap:var(--spacing-6)}.nav-link{color:var(--color-gray-600);text-decoration:none;font-weight:500;padding:var(--spacing-2) 0;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.nav-link:hover,.nav-link.active{color:var(--color-primary);border-bottom-color:var(--color-primary);text-decoration:none}.header-actions{align-items:center;gap:var(--spacing-4)}.user-menu{display:flex;align-items:center;gap:var(--spacing-2);text-decoration:none;color:var(--color-gray-700)}.app-main{padding-bottom:0}.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}}.push-notification-toggle{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.push-notification-toggle.unsupported,.push-notification-toggle.denied{opacity:.7}.push-info{display:flex;align-items:center;gap:var(--spacing-2)}.push-icon{font-size:1.25rem}.push-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.push-hint{display:block;font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--spacing-1)}.push-toggle-btn{position:relative;width:52px;height:28px;padding:0;border:none;background:transparent;cursor:pointer}.push-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.toggle-track{display:block;width:100%;height:100%;background:var(--color-gray-300);border-radius:var(--radius-full);transition:background var(--transition-fast)}.push-toggle-btn.active .toggle-track{background:var(--color-primary)}.toggle-thumb{position:absolute;top:2px;left:2px;width:24px;height:24px;background:var(--color-white);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.push-toggle-btn.active .toggle-thumb{transform:translate(24px)}.push-notification-wrap{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.push-notification-btn{display:flex;align-items:center;gap:var(--spacing-2);height:36px;padding:0 var(--spacing-3);border:none;background:var(--color-gray-100);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.push-notification-btn:hover{background:var(--color-gray-200);color:var(--color-text-primary)}.push-notification-btn.subscribed{background:var(--color-primary-light);color:var(--color-primary)}.push-notification-btn.blocked{cursor:default;opacity:.6}.push-notification-btn:disabled{opacity:.5;cursor:not-allowed}.push-btn-icon{font-size:1rem;flex-shrink:0}.push-btn-label{font-size:var(--font-size-sm)}.push-btn-loading{font-size:var(--font-size-xs)}.push-btn-error{font-size:var(--font-size-xs);color:var(--color-error);padding-left:var(--spacing-2)}.notif-bell-wrap{position:relative}.notif-bell-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--color-gray-100);border-radius:var(--radius-full);cursor:pointer;color:var(--color-text-secondary);transition:background var(--transition-fast)}.notif-bell-btn:hover{background:var(--color-gray-200);color:var(--color-text-primary)}.notif-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;background:var(--color-error);color:#fff;font-size:11px;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center;line-height:1}.notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);z-index:1000;overflow:hidden}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);font-weight:600;font-size:var(--font-size-sm);border-bottom:1px solid var(--color-gray-100)}.notif-mark-all{font-size:var(--font-size-xs);color:var(--color-primary);background:none;border:none;cursor:pointer;font-weight:500}.notif-list{max-height:380px;overflow-y:auto}.notif-item{display:flex;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--color-gray-50)}.notif-item:hover{background:var(--color-gray-50)}.notif-item.unread{background:#f0f7ff}.notif-item.unread:hover{background:#e4f0fd}.notif-dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:var(--color-primary);margin-top:5px}.notif-body{flex:1;min-width:0}.notif-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:2px}.notif-message{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-time{font-size:11px;color:var(--color-gray-400);margin-top:4px}.notif-empty{padding:var(--spacing-6);text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.impersonate-bar{position:fixed;top:0;left:0;right:0;z-index:10000;background:#7c3aed;color:#fff;font-size:.75rem;text-align:center;padding:4px 16px;line-height:1.4;pointer-events:none}.search-hero{text-align:center;padding:var(--spacing-8) var(--spacing-4);background:var(--color-primary-gradient);color:var(--color-white);border-radius:var(--radius-2xl);margin-bottom:var(--spacing-6)}.search-hero h1{color:var(--color-white);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-2)}.search-hero p{color:#fffc;margin-bottom:var(--spacing-6)}.smart-search-form{display:flex;flex-direction:column;gap:var(--spacing-3);max-width:600px;margin:0 auto}.smart-search-input{position:relative;flex:1}.smart-search-input .search-icon{position:absolute;left:var(--spacing-4);top:50%;transform:translateY(-50%);font-size:1.25rem;z-index:1;pointer-events:none}.smart-search-input input{width:100%;padding-left:calc(var(--spacing-4) + 2rem);background:var(--color-white);border-radius:var(--radius-xl);height:52px;font-size:var(--font-size-base);border:none}.search-btn{height:52px;border-radius:var(--radius-xl);font-size:var(--font-size-base);font-weight:600}@media (min-width: 769px){.search-hero{padding:var(--spacing-12) var(--spacing-8)}.search-hero h1{font-size:var(--font-size-4xl)}.smart-search-form{flex-direction:row;align-items:stretch}.smart-search-input{flex:1}.search-btn{width:auto;min-width:120px;padding:0 var(--spacing-6)}}.suggestions-section{margin-bottom:var(--spacing-8)}.suggestion-chips{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin:var(--spacing-4) 0}.filters-row{display:flex;flex-direction:column;gap:var(--spacing-3);margin-bottom:var(--spacing-6);padding:var(--spacing-4);background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}@media (min-width: 769px){.filters-row{flex-direction:row;align-items:center}.filters-row>*{flex:1}.filters-row button{flex:0 0 auto}}.auth-card{width:100%;max-width:420px;padding:var(--spacing-8);background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.auth-title{font-size:var(--font-size-2xl);font-weight:700;text-align:center;margin-bottom:var(--spacing-2)}.auth-subtitle{text-align:center;color:var(--color-gray-600);margin-bottom:var(--spacing-6)}.auth-tabs{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-6)}.auth-tab{flex:1;padding:var(--spacing-3);background:var(--color-gray-100);border:none;border-radius:var(--radius-lg);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.auth-tab.active{background:var(--color-primary);color:var(--color-white)}.auth-steps{display:flex;justify-content:center;gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.auth-step{width:32px;height:32px;border-radius:50%;background:var(--color-gray-200);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-sm)}.auth-step.active{background:var(--color-primary);color:var(--color-white)}.auth-step.completed{background:var(--color-success);color:var(--color-white)}.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)}.whatsapp-otp-notice{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background-color:#dcf8c6;border-radius:var(--radius-md);margin-bottom:var(--spacing-2)}.whatsapp-otp-notice svg{flex-shrink:0}.whatsapp-otp-notice span{color:#075e54;font-size:var(--font-size-sm);font-weight:500}.page{padding:var(--spacing-8) 0}.page-header{margin-bottom:var(--spacing-8)}.page-header h1{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-2)}.page-header p{color:var(--color-gray-600)}.search-filters{display:flex;gap:var(--spacing-4);margin-bottom:var(--spacing-8);flex-wrap:wrap}.search-filters>*{flex:1;min-width:200px}.designers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-6)}.designer-card{overflow:hidden}.designer-card a{text-decoration:none;color:inherit}.designer-image{height:180px;background:var(--color-gray-100);position:relative}.designer-image img{width:100%;height:100%;object-fit:cover}.designer-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-4xl);font-weight:700;color:var(--color-gray-400)}.verified-badge{position:absolute;top:var(--spacing-2);right:var(--spacing-2);background:var(--color-primary);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}.designer-info{padding:var(--spacing-4)}.designer-info h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-1)}.designer-location{color:var(--color-gray-500);font-size:var(--font-size-sm);margin-bottom:var(--spacing-2)}.designer-rating{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.designer-rating span{color:var(--color-gray-500);font-size:var(--font-size-sm)}.designer-experience{color:var(--color-gray-600);font-size:var(--font-size-sm)}.designer-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-8);padding:var(--spacing-6);background:var(--color-white);border-radius:var(--radius-xl)}.designer-profile{display:flex;gap:var(--spacing-6)}.designer-avatar{width:120px;height:120px;border-radius:var(--radius-xl);background:var(--color-gray-100);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-4xl);font-weight:700;color:var(--color-primary)}.designer-avatar img{width:100%;height:100%;object-fit:cover}.designer-details h1{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-2)}.designer-details .verified-badge{position:static;font-size:var(--font-size-xs)}.designer-details .location{color:var(--color-gray-600);margin-bottom:var(--spacing-2)}.rating-row{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.designer-bio{background:var(--color-white);padding:var(--spacing-6);border-radius:var(--radius-xl);margin-bottom:var(--spacing-6)}.designer-bio h3{margin-bottom:var(--spacing-3)}.instagram-link{display:inline-flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-3);color:#e1306c;font-weight:500;text-decoration:none;font-size:.95rem}.instagram-link:hover{text-decoration:underline}.profile-tabs,.filter-tabs{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-6);border-bottom:1px solid var(--color-gray-200)}.tab,.filter-tab{padding:var(--spacing-3) var(--spacing-4);background:none;border:none;font-weight:500;color:var(--color-gray-600);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition-fast)}.tab.active,.filter-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-4)}.portfolio-item{aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden}.portfolio-item img{width:100%;height:100%;object-fit:cover}.reviewer-name{color:var(--color-gray-500);font-size:var(--font-size-sm);margin-top:var(--spacing-2)}.designer-response{margin-top:var(--spacing-4);padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-md)}.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;align-items:flex-start;margin-bottom:var(--spacing-3)}.visit-header h3{margin-bottom:var(--spacing-1)}.visit-project{color:var(--color-gray-600)}.status-badge{padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full);color:var(--color-white);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase}.visit-details{margin-bottom:var(--spacing-4)}.visit-details p{margin-bottom:var(--spacing-1);color:var(--color-gray-600)}.visit-actions{display:flex;gap:var(--spacing-2)}.profile-info{display:flex;gap:var(--spacing-8)}.profile-avatar{width:100px;height:100px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:var(--color-white);font-size:var(--font-size-3xl);font-weight:700}.profile-details{flex:1}.detail-row{display:flex;padding:var(--spacing-3) 0;border-bottom:1px solid var(--color-gray-100)}.detail-row label{width:150px;font-weight:500;color:var(--color-gray-500)}.empty-state{text-align:center;padding:var(--spacing-16) var(--spacing-4)}.empty-state h3{margin-bottom:var(--spacing-2)}.empty-state p{color:var(--color-gray-600);margin-bottom:var(--spacing-4)}.loading-container{display:flex;justify-content:center;padding:var(--spacing-16)}@media (max-width: 768px){.designer-header{flex-direction:column;gap:var(--spacing-4)}.designer-profile{flex-direction:column;text-align:center}.designer-avatar{margin:0 auto}.profile-info{flex-direction:column;align-items:center;text-align:center}.detail-row{flex-direction:column;gap:var(--spacing-1)}.detail-row label{width:auto}}.review-form-card{margin-bottom:var(--spacing-6);border:2px solid var(--color-primary-light)}.review-form-card h2{margin-bottom:var(--spacing-2)}.review-for{color:var(--color-gray-600);margin-bottom:var(--spacing-4)}.form-group{margin-bottom:var(--spacing-4)}.form-group label{display:block;font-weight:500;margin-bottom:var(--spacing-2)}.rating-selector{display:flex;align-items:center;gap:var(--spacing-1)}.star-btn{background:none;border:none;font-size:2rem;color:var(--color-gray-300);cursor:pointer;padding:0;transition:transform .1s}.star-btn:hover{transform:scale(1.1)}.star-btn.active{color:var(--color-accent)}.rating-text{margin-left:var(--spacing-3);color:var(--color-gray-600);font-size:var(--font-size-sm)}.form-actions{display:flex;gap:var(--spacing-3);justify-content:flex-end;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;align-items:flex-start;margin-bottom:var(--spacing-3)}.review-header h3{margin-bottom:var(--spacing-1)}.review-date{color:var(--color-gray-500);font-size:var(--font-size-sm)}.review-text{color:var(--color-gray-700);line-height:1.6}.designer-response{margin-top:var(--spacing-4);padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.designer-response strong{display:block;margin-bottom:var(--spacing-1);color:var(--color-primary);font-size:var(--font-size-sm)}.designer-response p{margin:0;color:var(--color-gray-700)}.help-hero{text-align:center;padding:var(--spacing-8) var(--spacing-4);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-radius:var(--radius-2xl);color:var(--color-white);margin-bottom:var(--spacing-6)}.ai-avatar-large{font-size:4rem;margin-bottom:var(--spacing-4);animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.help-hero h1{color:var(--color-white);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-2)}.help-hero p{color:#ffffffe6;font-size:var(--font-size-lg)}.suggestions-section{margin-bottom:var(--spacing-6)}.suggestions-section h3{font-size:var(--font-size-base);color:var(--color-gray-700);margin-bottom:var(--spacing-3)}.suggestions-list{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.faq-section{margin-bottom:var(--spacing-6)}.faq-section h2{font-size:var(--font-size-xl);margin-bottom:var(--spacing-4)}.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;text-align:left;font-size:var(--font-size-base);font-weight:500;color:var(--color-gray-900);cursor:pointer;transition:background var(--transition-fast)}.faq-question:hover{background:var(--color-gray-50)}.faq-icon{font-size:var(--font-size-xl);color:var(--color-primary)}.faq-answer{padding:0 var(--spacing-4) var(--spacing-4);color:var(--color-gray-600);line-height:1.6;border-top:1px solid var(--color-gray-100);background:var(--color-gray-50)}.faq-item.expanded .faq-question{background:var(--color-gray-50)}.floating-ai-btn{position:fixed;bottom:var(--spacing-6);right:var(--spacing-6);display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);background:var(--color-primary-gradient);color:var(--color-white);border-radius:var(--radius-full);text-decoration:none;font-weight:600;box-shadow:var(--shadow-lg);transition:all var(--transition-fast);z-index:100}.floating-ai-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl);text-decoration:none;color:var(--color-white)}.floating-ai-btn .ai-icon{font-size:1.5rem}.desktop-only{display:none}@media (min-width: 769px){.desktop-only{display:flex}.help-hero{padding:var(--spacing-12) var(--spacing-8)}.help-hero h1{font-size:var(--font-size-3xl)}}.filter-tabs{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-gray-200);overflow-x:auto;-webkit-overflow-scrolling:touch}.filter-tab{padding:var(--spacing-2) var(--spacing-4);background:none;border:none;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-600);cursor:pointer;white-space:nowrap;transition:all .2s ease}.filter-tab:hover{background:var(--color-gray-100)}.filter-tab.active{background:var(--color-primary);color:var(--color-white)}.projects-list{display:flex;flex-direction:column;gap:var(--spacing-4)}.project-card{padding:var(--spacing-4);transition:transform .2s ease,box-shadow .2s ease}.project-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-3)}.project-info{flex:1}.project-title{font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--spacing-1) 0}.project-designer{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:0}.project-status{padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;color:var(--color-white);text-transform:uppercase}.project-description{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:0 0 var(--spacing-4) 0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-progress{margin-bottom:var(--spacing-4)}.progress-header{display:flex;justify-content:space-between;font-size:var(--font-size-sm);margin-bottom:var(--spacing-2)}.progress-bar{height:6px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width .3s ease}.project-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-4);padding:var(--spacing-3) 0;border-top:1px solid var(--color-gray-100);border-bottom:1px solid var(--color-gray-100);margin-bottom:var(--spacing-3)}.meta-item{display:flex;flex-direction:column;gap:var(--spacing-1)}.meta-label{font-size:var(--font-size-xs);color:var(--color-gray-500)}.meta-value{font-size:var(--font-size-sm);font-weight:500}.project-footer{display:flex;justify-content:space-between;align-items:center}.project-stats{display:flex;gap:var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-gray-500)}.project-detail-page{padding-bottom:var(--spacing-8)}.project-detail-page .project-header{display:flex;flex-direction:column;gap:var(--spacing-3);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--color-gray-200)}.project-detail-page .back-btn{align-self:flex-start;padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-gray-600)}.project-header-info{width:100%}.project-header-info h1{font-size:var(--font-size-lg);font-weight:700;margin:0 0 var(--spacing-2) 0;line-height:1.3}.project-designer-name{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:0}.project-status-badge{display:inline-block;margin-top:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;text-transform:capitalize}.project-status-badge.status-draft{background:var(--color-gray-100);color:var(--color-gray-600)}.project-status-badge.status-active{background:var(--color-success-light, #dcfce7);color:var(--color-success)}.project-status-badge.status-on_hold{background:var(--color-warning-light, #fef3c7);color:var(--color-warning)}.project-status-badge.status-completed{background:var(--color-info-light, #dbeafe);color:var(--color-info)}.project-status-badge.status-cancelled{background:var(--color-error-light, #fee2e2);color:var(--color-error)}@media (min-width: 640px){.project-detail-page .project-header{flex-direction:row;flex-wrap:wrap;align-items:center;gap:var(--spacing-4)}.project-detail-page .back-btn{align-self:center}.project-header-info{flex:1;min-width:200px;width:auto}.project-header-info h1{font-size:var(--font-size-xl)}.project-status-badge{margin-top:0}}.project-tabs{display:flex;gap:0;margin:0 calc(-1 * var(--spacing-4));margin-bottom:var(--spacing-4);padding:0 var(--spacing-2);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;background:var(--color-gray-50);border-top:1px solid var(--color-gray-200);border-bottom:1px solid var(--color-gray-200)}.project-tabs::-webkit-scrollbar{display:none}.project-tab{flex:1;min-width:0;padding:var(--spacing-4) var(--spacing-2);background:none;border:none;border-bottom:3px solid transparent;font-size:var(--font-size-xs);font-weight:600;color:var(--color-gray-500);cursor:pointer;white-space:nowrap;transition:all .2s ease;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1)}.project-tab:before{font-size:1.25rem;display:block}.project-tab:nth-child(1):before{content:"📋"}.project-tab:nth-child(2):before{content:"🎯"}.project-tab:nth-child(3):before{content:"📄"}.project-tab:nth-child(4):before{content:"💬"}.project-tab:nth-child(5):before{content:"📅"}.project-tab:hover{color:var(--color-primary);background:var(--color-gray-100)}.project-tab:active{background:var(--color-gray-200)}.project-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);background:#fff}@media (min-width: 640px){.project-tabs{margin:0;margin-bottom:var(--spacing-6);padding:0;background:transparent;border-top:none;border-bottom:2px solid var(--color-gray-200);gap:var(--spacing-1)}.project-tab{flex:none;flex-direction:row;padding:var(--spacing-3) var(--spacing-5);font-size:var(--font-size-sm);margin-bottom:-2px;border-bottom-width:2px}.project-tab:before{font-size:1rem}.project-tab:hover,.project-tab.active{background:transparent}}.overview-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-4)}@media (min-width: 769px){.overview-grid{grid-template-columns:repeat(2,1fr)}}.overview-card{padding:var(--spacing-5)}.overview-card.full-width{grid-column:1 / -1}.overview-card h3{font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--spacing-4) 0;color:var(--color-gray-700)}.progress-circle-container{display:flex;justify-content:center;margin-bottom:var(--spacing-4)}.progress-circle{position:relative;width:120px;height:120px}.progress-circle svg{transform:rotate(-90deg)}.progress-circle .progress-bg{fill:none;stroke:var(--color-gray-200);stroke-width:3}.progress-circle .progress-fill{fill:none;stroke:var(--color-primary);stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .5s ease}.progress-circle .progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary)}.progress-label{text-align:center;font-size:var(--font-size-sm);color:var(--color-gray-500)}.detail-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.detail-item{display:flex;justify-content:space-between;padding-bottom:var(--spacing-2);border-bottom:1px solid var(--color-gray-100)}.detail-label{font-size:var(--font-size-sm);color:var(--color-gray-500)}.detail-value{font-size:var(--font-size-sm);font-weight:500}.meetings-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.meeting-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-md)}.meeting-info{display:flex;flex-direction:column;gap:var(--spacing-1)}.meeting-title{font-weight:500}.meeting-time{font-size:var(--font-size-sm);color:var(--color-gray-500)}.meeting-type{font-size:var(--font-size-xs);color:var(--color-gray-500)}.milestones-timeline{display:flex;flex-direction:column;gap:0}.milestone-item{display:flex;gap:var(--spacing-4)}.milestone-marker{display:flex;flex-direction:column;align-items:center;padding-top:var(--spacing-4)}.marker-dot{width:16px;height:16px;border-radius:50%;border:3px solid var(--color-white);box-shadow:0 0 0 2px var(--color-gray-300)}.marker-line{width:2px;flex:1;background:var(--color-gray-200);margin-top:var(--spacing-2)}.milestone-card{flex:1;margin-bottom:var(--spacing-4);padding:var(--spacing-4)}.milestone-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2)}.milestone-header h4{margin:0;font-size:var(--font-size-base)}.milestone-status{font-size:var(--font-size-xs);font-weight:600}.milestone-description{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:0 0 var(--spacing-3) 0}.milestone-meta{display:flex;gap:var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-gray-500);margin-bottom:var(--spacing-3)}.milestone-actions{padding-top:var(--spacing-3);border-top:1px solid var(--color-gray-100)}.milestone-feedback{padding:var(--spacing-3);background:var(--color-warning-light, #fef3c7);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-top:var(--spacing-3)}.documents-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}@media (min-width: 769px){.documents-grid{grid-template-columns:repeat(3,1fr)}}.document-card{padding:0;overflow:hidden;transition:transform .2s ease}.document-card:hover{transform:scale(1.02)}.document-thumbnail{position:relative;aspect-ratio:1;background:var(--color-gray-100)}.document-thumbnail img{width:100%;height:100%;object-fit:cover}.document-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;background:linear-gradient(135deg,var(--color-gray-100),var(--color-gray-200))}.approval-badge{position:absolute;top:var(--spacing-2);right:var(--spacing-2);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:var(--font-size-sm);font-weight:600}.approval-badge.approved{background:var(--color-success);color:#fff}.approval-badge.revision_requested{background:var(--color-warning);color:#fff}.approval-badge.pending{background:var(--color-gray-300);color:#fff}.document-info{padding:var(--spacing-3)}.document-type{font-size:var(--font-size-xs);color:var(--color-gray-500);text-transform:uppercase}.document-info h4{margin:var(--spacing-1) 0;font-size:var(--font-size-sm);font-weight:500}.document-date{font-size:var(--font-size-xs);color:var(--color-gray-400)}.messages-content{display:flex;flex-direction:column;height:calc(100vh - 280px);min-height:400px;max-height:600px;background:var(--color-gray-50);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md)}.messages-list{flex:1;overflow-y:auto;padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-3);background:linear-gradient(to bottom,var(--color-gray-100),var(--color-gray-50))}.empty-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--color-gray-400);text-align:center;padding:var(--spacing-6)}.empty-messages:before{content:"💬";font-size:3rem;margin-bottom:var(--spacing-3);opacity:.5}.empty-messages p{font-size:var(--font-size-sm);max-width:200px}.message-bubble{max-width:85%;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-xl);position:relative;animation:messageSlide .2s ease-out}@keyframes messageSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-bubble.own{align-self:flex-end;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark, #1a5f4a));color:#fff;border-bottom-right-radius:var(--spacing-1);box-shadow:0 2px 8px #1a5f4a40}.message-bubble.other{align-self:flex-start;background:#fff;border-bottom-left-radius:var(--spacing-1);box-shadow:0 2px 8px #00000014}.message-content{font-size:var(--font-size-base);line-height:1.5;word-wrap:break-word}.message-meta{display:flex;justify-content:space-between;gap:var(--spacing-3);margin-top:var(--spacing-2);font-size:var(--font-size-xs);opacity:.75}.message-bubble.own .message-meta{justify-content:flex-end}.message-sender{font-weight:500}.message-input-form{display:flex;gap:var(--spacing-3);padding:var(--spacing-4);background:#fff;border-top:1px solid var(--color-gray-200);align-items:flex-end}.message-input-form .input-group{flex:1;margin:0}.message-input-form input{flex:1;padding:var(--spacing-4);font-size:var(--font-size-base);border-radius:var(--radius-full);border:2px solid var(--color-gray-200);transition:border-color .2s ease}.message-input-form input:focus{border-color:var(--color-primary);outline:none}.message-input-form button{width:52px;height:52px;min-width:52px;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:0 2px 8px #1a5f4a4d}.message-input-form button:before{content:"➤"}.message-input-form button span{display:none}@media (min-width: 640px){.messages-content{height:500px;max-height:none}.message-bubble{max-width:70%}.message-input-form button{width:auto;min-width:100px;height:auto;padding:var(--spacing-3) var(--spacing-5);border-radius:var(--radius-lg)}.message-input-form button:before{display:none}.message-input-form button span{display:inline}}.activity-timeline{display:flex;flex-direction:column;gap:0;padding-left:var(--spacing-4);border-left:2px solid var(--color-gray-200)}.timeline-event{position:relative;padding-left:var(--spacing-6);padding-bottom:var(--spacing-4)}.event-marker{position:absolute;left:calc(-1 * var(--spacing-4) - 5px);top:var(--spacing-1);width:10px;height:10px;background:var(--color-primary);border:2px solid white;border-radius:50%}.event-description{font-size:var(--font-size-sm);margin:0 0 var(--spacing-1) 0}.event-time{font-size:var(--font-size-xs);color:var(--color-gray-400)}.approval-modal-content{display:flex;flex-direction:column;gap:var(--spacing-4)}.approval-actions{display:flex;gap:var(--spacing-3);justify-content:flex-end;padding-top:var(--spacing-4);border-top:1px solid var(--color-gray-100)}.meetings-content{padding-bottom:var(--spacing-4)}.meetings-list-full{display:flex;flex-direction:column;gap:var(--spacing-4)}.meeting-card{padding:var(--spacing-4);border-radius:var(--radius-xl);border-left:4px solid var(--color-primary);transition:transform .2s ease,box-shadow .2s ease}.meeting-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.meeting-header{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.meeting-header h4{margin:0;font-size:var(--font-size-base);font-weight:600;order:2}.meeting-status{font-size:var(--font-size-xs);font-weight:600;order:1;align-self:flex-start;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);background:var(--color-gray-100);text-transform:capitalize}.meeting-status.scheduled{background:var(--color-info-light, #dbeafe);color:var(--color-info)}.meeting-status.completed{background:var(--color-success-light, #dcfce7);color:var(--color-success)}.meeting-status.cancelled{background:var(--color-error-light, #fee2e2);color:var(--color-error)}.meeting-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-3);margin-bottom:var(--spacing-2)}.meeting-duration{font-size:var(--font-size-sm);color:var(--color-gray-500)}.meeting-details{display:flex;flex-direction:column;gap:var(--spacing-1);font-size:var(--font-size-sm);color:var(--color-gray-500);margin-bottom:var(--spacing-2)}.meeting-description{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:var(--spacing-2) 0}.document-annotation-modal{display:flex;flex-direction:column;gap:var(--spacing-4);min-height:500px}.loading-comments{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;gap:var(--spacing-3);color:var(--color-gray-500)}.document-actions{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4);background:var(--color-gray-50);border-radius:var(--radius-lg);margin-top:auto}.document-meta{display:flex;align-items:center;gap:var(--spacing-3)}.doc-version{font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-600);padding:var(--spacing-1) var(--spacing-2);background:var(--color-gray-200);border-radius:var(--radius-md)}.doc-status{font-size:var(--font-size-sm);font-weight:500;padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full)}.doc-status.pending{background:var(--color-warning-light, #fef3c7);color:var(--color-warning)}.doc-status.approved{background:var(--color-success-light, #dcfce7);color:var(--color-success)}.doc-status.revision_requested{background:var(--color-error-light, #fee2e2);color:var(--color-error)}.doc-approval-actions{display:flex;gap:var(--spacing-2)}.version-badge{position:absolute;top:var(--spacing-2);left:var(--spacing-2);font-size:var(--font-size-xs);font-weight:600;padding:2px 6px;background:var(--color-primary);color:#fff;border-radius:var(--radius-sm)}@media (max-width: 640px){.document-annotation-modal{min-height:400px}.document-actions{flex-direction:column;gap:var(--spacing-3);align-items:stretch}.document-meta{justify-content:center}.doc-approval-actions{flex-direction:column}}.studio-page{padding-bottom:80px}.studio-filters-bar{display:flex;gap:8px;overflow-x:auto;padding:14px 16px 10px;scrollbar-width:none;position:sticky;top:0;background:#fff;z-index:10;border-bottom:1px solid #F1F5F9}.studio-filters-bar::-webkit-scrollbar{display:none}.studio-chip{padding:6px 14px;border-radius:20px;border:1px solid #E2E8F0;background:#fff;font-size:.8rem;font-weight:500;color:#64748b;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .15s}.studio-chip:hover{border-color:#1e3a5f;color:#1e3a5f}.studio-chip.active{background:#1e3a5f;border-color:#1e3a5f;color:#fff;font-weight:600}.studio-grid{columns:2;column-gap:8px;padding:10px 8px 0}@media (min-width: 480px){.studio-grid{columns:3;column-gap:10px}}@media (min-width: 768px){.studio-grid{columns:3;column-gap:14px;padding:14px 16px 0}}@media (min-width: 1024px){.studio-grid{columns:4;column-gap:16px;padding:16px 24px 0}}.studio-card{break-inside:avoid;margin-bottom:8px;border-radius:10px;overflow:hidden;background:#fff;cursor:pointer;box-shadow:0 1px 3px #00000012;transition:transform .18s,box-shadow .18s}@media (min-width: 768px){.studio-card{margin-bottom:14px;border-radius:12px}.studio-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}}.studio-card-img{position:relative;overflow:hidden}.studio-card-img img{width:100%;display:block;object-fit:cover}.studio-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a6b;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.studio-card:hover .studio-card-overlay{opacity:1}.studio-card-cta{color:#fff;font-size:.82rem;font-weight:600;background:#ffffff2e;padding:6px 14px;border-radius:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.studio-card-tag{position:absolute;top:8px;left:8px;background:#0f172ab8;color:#fff;font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:10px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.studio-card-info{padding:8px 10px 10px}.studio-card-title{font-size:.78rem;font-weight:600;color:#0f172a;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.studio-card-designer{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.studio-card-name{font-size:.75rem;font-weight:500;color:#1e3a5f}.studio-card-city{font-size:.68rem;color:#94a3b8}.studio-card-rating{font-size:.68rem;color:#f59e0b;font-weight:600;margin-left:auto}.studio-skeleton{break-inside:avoid;margin-bottom:8px;border-radius:10px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;height:180px}.studio-skeleton:nth-child(2n){height:240px}.studio-skeleton:nth-child(3n){height:160px}.studio-empty{text-align:center;padding:60px 24px;color:#64748b;font-size:.9rem}.studio-load-more{text-align:center;padding:24px 16px 40px}.studio-load-btn{padding:11px 28px;background:#1e3a5f;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.studio-load-btn:hover{background:#2e5a8f}.studio-load-btn:disabled{opacity:.6;cursor:not-allowed}.studio-card-actions{margin-top:6px;display:flex;gap:8px}.studio-comment-btn{font-size:.75rem;color:#64748b;background:none;border:none;cursor:pointer;padding:0;font-family:inherit;font-weight:500}.studio-comment-btn:hover{color:#1e3a5f}.comment-panel{border-top:1px solid #F1F5F9;background:#fafbfc}.comment-panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:.78rem;font-weight:600;color:#334155}.comment-panel-close{background:none;border:none;cursor:pointer;color:#94a3b8;font-size:1rem;line-height:1;padding:0}.comment-list{max-height:180px;overflow-y:auto;padding:0 12px 4px}.comment-loading,.comment-empty{font-size:.78rem;color:#94a3b8;text-align:center;padding:12px 0;margin:0}.comment-item{display:flex;gap:8px;align-items:flex-start;padding:6px 0;border-bottom:1px solid #F1F5F9}.comment-item:last-child{border-bottom:none}.comment-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#1e3a5f,#2e5a8f);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.comment-body{flex:1;min-width:0}.comment-name{font-size:.72rem;font-weight:600;color:#334155;display:block}.comment-text{font-size:.78rem;color:#475569;margin:2px 0 0;word-break:break-word}.comment-delete{background:none;border:none;color:#cbd5e1;cursor:pointer;font-size:1rem;line-height:1;padding:0;flex-shrink:0}.comment-delete:hover{color:#ef4444}.comment-form{display:flex;gap:6px;padding:8px 12px 10px;border-top:1px solid #F1F5F9}.comment-input{flex:1;border:1px solid #E2E8F0;border-radius:16px;padding:6px 12px;font-size:.78rem;font-family:inherit;outline:none;background:#fff}.comment-input:focus{border-color:#1e3a5f}.comment-submit{padding:6px 14px;background:#1e3a5f;color:#fff;border:none;border-radius:16px;font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap}.comment-submit:disabled{opacity:.5;cursor:not-allowed}
