.fulfillment-card{border:1px solid #e5e7eb;border-radius:8px;padding:1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:border-color .15s}.fulfillment-card:hover{border-color:#3b82f6}.fulfillment-badge{padding:2px 10px;border-radius:12px;font-size:.8rem;font-weight:600}.fulfillment-badge--draft{background:#fef3c7;color:#92400e}.fulfillment-badge--complete{background:#d1fae5;color:#065f46}.fulfillment-badge--exported{background:#dbeafe;color:#1e40af}.fulfillment-summary-bar{display:flex;gap:1.5rem;margin-bottom:1rem;padding:.75rem 1rem;background:#f8fafc;border-radius:6px}.fulfillment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.circuit-card{border:1px solid #e5e7eb;border-radius:8px;padding:1rem;margin-bottom:.75rem;background:#fafafa}.circuit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}@tailwind base;@tailwind components;@tailwind utilities;@layer base{body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--line-height-normal);color:var(--color-neutral-900);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}*:focus:not(:focus-visible){outline:none}}@layer components{.form-control{@apply w-full px-3 py-2 text-base;@apply border border-neutral-300 rounded-md;@apply bg-white text-neutral-900;@apply transition-colors duration-150;@apply focus:outline-none focus:ring-2 focus:ring-primary-500 focus:border-transparent;@apply disabled:bg-neutral-100 disabled:text-neutral-500 disabled:cursor-not-allowed;}.form-control:hover:not(:disabled){@apply border-neutral-400;}.form-control.error{@apply border-error-500 focus:ring-error-500;}.form-label{@apply block text-sm font-medium text-neutral-700 mb-1;}.form-label.required:after{content:" *";@apply text-error-500;}.form-error{@apply text-sm text-error-600 mt-1 flex items-start gap-1;}.form-help{@apply text-sm text-neutral-600 mt-1;}.form-field{@apply mb-4;}.btn{@apply inline-flex items-center justify-center gap-2;@apply px-4 py-2 text-base font-medium rounded-md;@apply transition-all duration-150;@apply focus:outline-none focus:ring-2 focus:ring-offset-2;@apply disabled:opacity-50 disabled:cursor-not-allowed;}.btn-primary{@apply bg-primary-500 text-white;@apply hover:bg-primary-600 active:bg-primary-700;@apply focus:ring-primary-500;}.btn-secondary{@apply bg-neutral-200 text-neutral-900;@apply hover:bg-neutral-300 active:bg-neutral-400;@apply focus:ring-neutral-500;}.btn-danger{@apply bg-error-500 text-white;@apply hover:bg-error-600 active:bg-error-700;@apply focus:ring-error-500;}.text-technical{font-family:var(--font-mono);@apply text-sm;}}@layer utilities{.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.not-sr-only{position:static;width:auto;height:auto;padding:0;margin:0;overflow:visible;clip:auto;white-space:normal}}.btn{all:unset;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--font-sans);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;white-space:nowrap;position:relative}.btn:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{height:var(--button-height-sm);padding:0 var(--button-padding-x-sm);font-size:var(--button-font-size-sm)}.btn-md{height:var(--button-height-md);padding:0 var(--button-padding-x-md);font-size:var(--button-font-size-md)}.btn-lg{height:var(--button-height-lg);padding:0 var(--button-padding-x-lg);font-size:var(--button-font-size-lg)}.btn-primary{background-color:var(--color-primary-500);color:var(--color-text-on-primary);border:1px solid transparent}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-600)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-700)}.btn-secondary{background-color:var(--color-surface-secondary);color:var(--color-text-primary);border:1px solid var(--color-border-default)}.btn-secondary:hover:not(:disabled){background-color:var(--color-surface-tertiary);border-color:var(--color-border-hover)}.btn-ghost{background-color:transparent;color:var(--color-text-primary);border:1px solid transparent}.btn-ghost:hover:not(:disabled){background-color:var(--color-surface-secondary)}.btn-outline{background-color:transparent;color:var(--color-primary-600);border:1px solid var(--color-border-default)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary-50);border-color:var(--color-primary-500)}.btn-link{background-color:transparent;color:var(--color-text-link);border:1px solid transparent;text-decoration:underline;text-underline-offset:2px}.btn-link:hover:not(:disabled){color:var(--color-text-link-hover)}.btn-destructive{background-color:var(--color-error-500);color:var(--color-text-on-primary);border:1px solid transparent}.btn-destructive:hover:not(:disabled){background-color:var(--color-error-600)}.btn-loading{color:transparent!important}.btn-loading .btn-icon,.btn-loading .btn-content{visibility:hidden}.btn-spinner{position:absolute;width:1.25rem;height:1.25rem;color:currentColor}.btn-icon{display:flex;align-items:center;justify-content:center}.btn-content{display:flex;align-items:center}.form-select{all:unset;display:inline-flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;line-height:1.25rem;border-radius:.375rem;border:1px solid var(--color-border-default);background-color:var(--color-surface-primary);color:var(--color-text-primary);cursor:pointer;min-width:200px}.form-select:hover{border-color:var(--color-border-hover)}.form-select:focus{outline:2px solid var(--color-border-focus);outline-offset:2px;border-color:var(--color-border-focus)}.form-select-error{border-color:var(--color-border-error)}.form-select-error:focus{outline-color:var(--color-border-error);border-color:var(--color-border-error)}.form-select-icon{color:var(--color-text-secondary)}.form-select-content{overflow:hidden;background-color:#fff;border-radius:.375rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border:1px solid #e5e7eb}.form-select-viewport{padding:.25rem}.form-select-item{all:unset;display:flex;align-items:center;padding:.5rem 2rem .5rem .75rem;font-size:.875rem;line-height:1.25rem;border-radius:.25rem;cursor:pointer;position:relative;-webkit-user-select:none;user-select:none}.form-select-item:hover{background-color:#f3f4f6;outline:none}.form-select-item[data-highlighted]{background-color:#eff6ff;color:#1e40af;outline:none}.form-select-item[data-disabled]{color:#9ca3af;pointer-events:none}.form-select-indicator{position:absolute;right:.5rem;width:1rem;display:inline-flex;align-items:center;justify-content:center}.form-checkbox-wrapper{display:flex;align-items:center;gap:.5rem}.form-checkbox{all:unset;width:1.25rem;height:1.25rem;border-radius:.25rem;display:flex;align-items:center;justify-content:center;border:2px solid #d1d5db;background-color:#fff;cursor:pointer}.form-checkbox:hover{border-color:#9ca3af}.form-checkbox:focus{outline:2px solid #3b82f6;outline-offset:2px}.form-checkbox[data-state=checked]{background-color:#3b82f6;border-color:#3b82f6}.form-checkbox-error{border-color:#dc2626}.form-checkbox-error:focus{outline-color:#dc2626}.form-checkbox-indicator{color:#fff;display:flex;align-items:center;justify-content:center}.form-checkbox-label{font-size:.875rem;line-height:1.25rem;color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none}.form-radiogroup{display:flex;gap:.75rem}.form-radiogroup-vertical{flex-direction:column}.form-radiogroup-horizontal{flex-direction:row}.form-radio-item{display:flex;align-items:center;gap:.5rem}.form-radio{all:unset;width:1.25rem;height:1.25rem;border-radius:50%;border:2px solid #d1d5db;background-color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.form-radio:hover{border-color:#9ca3af}.form-radio:focus{outline:2px solid #3b82f6;outline-offset:2px}.form-radio[data-state=checked]{border-color:#3b82f6}.form-radio-error{border-color:#dc2626}.form-radio-error:focus{outline-color:#dc2626}.form-radio-indicator{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative}.form-radio-indicator:after{content:"";display:block;width:.625rem;height:.625rem;border-radius:50%;background-color:#3b82f6}.form-radio-label{font-size:.875rem;line-height:1.25rem;color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none}.form-label-required{color:var(--color-error-600);margin-left:.25rem}.badge{display:inline-flex;align-items:center;border-radius:var(--radius-md);font-weight:var(--font-weight-medium);border:1px solid}.badge-sm{padding:.125rem .5rem;font-size:var(--text-xs)}.badge-md{padding:.25rem .625rem;font-size:var(--text-sm)}.badge-lg{padding:.375rem .75rem;font-size:var(--text-base)}.badge-default{background-color:var(--color-neutral-100);color:var(--color-neutral-700);border-color:var(--color-neutral-300)}.badge-success{background-color:var(--color-success-50);color:var(--color-success-600);border-color:var(--color-success-500)}.badge-error{background-color:var(--color-error-50);color:var(--color-error-600);border-color:var(--color-error-500)}.badge-warning{background-color:var(--color-warning-50);color:var(--color-warning-600);border-color:var(--color-warning-500)}.badge-info{background-color:var(--color-info-50);color:var(--color-info-600);border-color:var(--color-info-500)}.spinner{display:inline-flex;align-items:center;justify-content:center}.spinner-sm{width:1rem;height:1rem}.spinner-md{width:1.5rem;height:1.5rem}.spinner-lg{width:2rem;height:2rem}.spinner-icon{width:100%;height:100%;color:var(--color-primary-500)}.spinner-circle{animation:spinner-rotate 1s linear infinite;transform-origin:center}@keyframes spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--color-surface-overlay);z-index:var(--z-modal-backdrop);animation:modal-overlay-fade-in .15s}@keyframes modal-overlay-fade-in{0%{opacity:0}to{opacity:1}}.modal-content{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:var(--color-surface-primary);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-6);z-index:var(--z-modal);max-height:85vh;overflow-y:auto;animation:modal-content-show .15s}@keyframes modal-content-show{0%{opacity:0;transform:translate(-50%,-48%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.modal-sm{max-width:var(--modal-max-width-sm)}.modal-md{max-width:var(--modal-max-width-md)}.modal-lg{max-width:var(--modal-max-width-lg)}.modal-xl{max-width:var(--modal-max-width-xl)}.modal-title{font-size:var(--text-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.modal-description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4)}.modal-body{color:var(--color-text-primary)}.modal-close{position:absolute;top:var(--space-4);right:var(--space-4);width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:1.5rem;line-height:1}.modal-close:hover{background-color:var(--color-surface-secondary);color:var(--color-text-primary)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--color-border-default)}.alert{display:flex;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid}.alert-success{background-color:var(--color-success-50);border-color:var(--color-success-500);color:var(--color-success-600)}.alert-error{background-color:var(--color-error-50);border-color:var(--color-error-500);color:var(--color-error-600)}.alert-warning{background-color:var(--color-warning-50);border-color:var(--color-warning-500);color:var(--color-warning-600)}.alert-info{background-color:var(--color-info-50);border-color:var(--color-info-500);color:var(--color-info-600)}.alert-icon{flex-shrink:0;display:flex;align-items:flex-start;padding-top:.125rem}.alert-content{flex:1}.alert-title{font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1)}.alert-description{font-size:var(--text-sm)}.alert-dismiss{flex-shrink:0;border:none;background:transparent;color:currentColor;cursor:pointer;font-size:1.25rem;line-height:1;padding:0;opacity:.7}.alert-dismiss:hover{opacity:1}.tooltip-content{background-color:var(--color-neutral-900);color:var(--color-text-on-primary);font-size:var(--text-sm);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:var(--z-tooltip);animation:tooltip-fade-in .15s}@keyframes tooltip-fade-in{0%{opacity:0}to{opacity:1}}.tooltip-arrow{fill:var(--color-neutral-900)}[data-theme=dark] .tooltip-content{background-color:var(--color-neutral-700)}[data-theme=dark] .tooltip-arrow{fill:var(--color-neutral-700)}.card{background-color:var(--color-surface-primary);border-radius:var(--radius-lg)}.card-default{border:1px solid var(--color-border-default)}.card-bordered{border:2px solid var(--color-border-default)}.card-elevated{border:1px solid var(--color-border-default);box-shadow:var(--shadow-lg)}.card-header{padding:var(--space-6);border-bottom:1px solid var(--color-border-default)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-6);border-top:1px solid var(--color-border-default);background-color:var(--color-surface-secondary);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.separator{background-color:var(--color-border-default)}.separator-horizontal{height:1px;width:100%}.separator-vertical{width:1px;height:100%}.progress-wrapper{display:flex;align-items:center;gap:var(--space-3)}.progress{position:relative;overflow:hidden;background-color:var(--color-neutral-200);border-radius:var(--radius-md);width:100%}.progress-sm{height:.5rem}.progress-md{height:.75rem}.progress-lg{height:1rem}.progress-indicator{background-color:var(--color-primary-500);width:100%;height:100%;transition:transform var(--transition-normal)}.progress-success .progress-indicator{background-color:var(--color-success-500)}.progress-warning .progress-indicator{background-color:var(--color-warning-500)}.progress-error .progress-indicator{background-color:var(--color-error-500)}.progress-label{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);min-width:3rem;text-align:right}.tabs{width:100%}.tabs-list{display:flex;border-bottom:1px solid var(--color-border-default)}.tabs-vertical .tabs-list{flex-direction:column;border-bottom:none;border-right:1px solid var(--color-border-default)}.tabs-trigger{all:unset;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.tabs-trigger:hover{color:var(--color-text-primary)}.tabs-trigger[data-state=active]{color:var(--color-primary-600);border-bottom-color:var(--color-primary-600)}.tabs-trigger:disabled{color:var(--color-text-disabled);cursor:not-allowed}.tabs-content{padding:var(--space-6) 0;color:var(--color-text-primary)}.accordion{width:100%}.accordion-item{border-bottom:1px solid var(--color-border-default)}.accordion-trigger{all:unset;display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-4) 0;font-size:var(--text-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.accordion-trigger:hover{color:var(--color-primary-600)}.accordion-trigger:disabled{color:var(--color-text-disabled);cursor:not-allowed}.accordion-chevron{transition:transform var(--transition-fast)}.accordion-trigger[data-state=open] .accordion-chevron{transform:rotate(180deg)}.accordion-content{overflow:hidden;font-size:var(--text-sm);color:var(--color-text-secondary);animation:accordion-slide-down .15s}.accordion-content[data-state=closed]{animation:accordion-slide-up .15s}@keyframes accordion-slide-down{0%{height:0;opacity:0}to{height:var(--radix-accordion-content-height);opacity:1}}@keyframes accordion-slide-up{0%{height:var(--radix-accordion-content-height);opacity:1}to{height:0;opacity:0}}.autocomplete-select{position:relative;width:100%}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;margin-top:.25rem;max-height:300px;overflow-y:auto;background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;box-shadow:0 10px 15px -3px #0000001a}.autocomplete-option{padding:.5rem .75rem;cursor:pointer}.autocomplete-option:hover,.autocomplete-option-highlighted{background-color:#f3f4f6}.autocomplete-loading,.autocomplete-empty{padding:.75rem;text-align:center;color:#6b7280}.pattern-input-wrapper{width:100%}.pattern-input-container{position:relative;display:flex;align-items:center;gap:.5rem}.pattern-input-indicator{display:flex;align-items:center;justify-content:center}.pattern-input-icon-success{color:#10b981}.pattern-input-icon-error{color:#ef4444}.pattern-input-error-message{margin-top:.25rem;font-size:.875rem;color:#ef4444}.pattern-input-spinner{width:16px;height:16px;border:2px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin .6s linear infinite}.repeating-field-group{width:100%}.repeating-field-group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.repeating-field-group-title{font-size:1.125rem;font-weight:600;color:#111827}.repeating-field-group-count{font-size:.875rem;color:#6b7280}.repeating-field-group-items{display:flex;flex-direction:column;gap:1rem}.repeating-field-group-item{border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem}.repeating-field-group-add-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;margin-top:1rem;padding:.75rem;border:2px dashed #d1d5db;border-radius:.375rem;background-color:#fff;color:#374151;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.repeating-field-group-add-button:hover{border-color:#9ca3af;background-color:#f9fafb}.repeating-field-group-error{margin-top:.5rem;padding:.75rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;color:#dc2626;font-size:.875rem}.composite-field{width:100%}.composite-field-label{font-size:1rem;font-weight:600;color:#111827;margin-bottom:.75rem}.composite-field-content{display:flex;gap:1rem}.composite-field-column{flex-direction:column}.composite-field-row{flex-direction:row}.composite-field-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.evc-field-group{border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;background-color:#fafafa}.evc-field-group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.evc-field-group-title{font-size:1.125rem;font-weight:600;color:#111827}.evc-field-group-actions{display:flex;gap:.5rem}.evc-action-button{padding:.375rem .75rem;border:1px solid #d1d5db;border-radius:.25rem;background-color:#fff;color:#374151;font-size:.875rem;cursor:pointer;transition:all .2s}.evc-action-button:hover{background-color:#f3f4f6}.evc-action-remove{color:#dc2626;border-color:#dc2626}.evc-action-remove:hover{background-color:#fef2f2}.evc-field-group-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.evc-summary{margin-top:1.5rem;padding:1rem;border-radius:.5rem;border:2px solid}.evc-summary-success{background-color:#f0fdf4;border-color:#86efac}.evc-summary-caution{background-color:#fffbeb;border-color:#fde047}.evc-summary-warning{background-color:#fef3c7;border-color:#fbbf24}.evc-summary-error{background-color:#fef2f2;border-color:#fca5a5}.evc-summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.evc-summary-title{font-size:1rem;font-weight:600}.evc-summary-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.evc-summary-stat{display:flex;justify-content:space-between}.evc-summary-stat-label{font-size:.875rem;color:#6b7280}.evc-summary-stat-value{font-size:.875rem;font-weight:600;color:#111827}.vlan-stack-input{width:100%}.vlan-stack-input-controls{display:flex;gap:.5rem;align-items:center}.vlan-type-select{width:120px;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;background-color:#fff;font-size:.875rem}.vlan-preview{margin-top:.75rem;padding:.75rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.75rem}.vlan-preview-header{font-weight:600;margin-bottom:.5rem}.vlan-preview-details{display:flex;flex-direction:column;gap:.25rem}.vlan-tag{display:inline-block;margin-top:.5rem;padding:.25rem .5rem;border-radius:.25rem;font-weight:600;font-family:monospace}.vlan-tag-s{background-color:#dbeafe;color:#1e40af}.vlan-tag-c{background-color:#e0e7ff;color:#4338ca}.vlan-error{margin-top:.5rem;padding:.5rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;color:#dc2626;font-size:.875rem}.port-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.pricing-summary{border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-6);background-color:var(--color-surface-primary)}.pricing-summary-header{margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-default)}.pricing-summary-title{font-size:var(--text-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.pricing-breakdown{margin-bottom:var(--space-4);padding:var(--space-4);background-color:var(--color-surface-secondary);border-radius:var(--radius-md)}.pricing-line{display:flex;justify-content:space-between;padding:var(--space-2) 0;font-size:var(--text-sm);color:var(--color-text-secondary)}.pricing-discount{color:var(--color-success-600);font-weight:var(--font-weight-medium)}.pricing-totals{border-top:2px solid var(--color-border-default);padding-top:var(--space-4)}.pricing-total-line{display:flex;justify-content:space-between;padding:var(--space-2) 0}.pricing-total-label{font-size:var(--text-base);color:var(--color-text-secondary)}.pricing-total-value{font-size:var(--text-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.pricing-highlight{background-color:var(--color-primary-50);margin:0 calc(-1 * var(--space-2));padding:var(--space-2);border-radius:var(--radius-sm)}.pricing-savings-badge{margin-top:var(--space-4)}.approval-workflow-header{display:flex;justify-content:space-between;align-items:center}.approval-details{display:grid;gap:var(--space-3)}.approval-detail{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-default)}.approval-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.approval-value{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.etree-endpoint{border:1px solid var(--color-border-default);border-radius:var(--radius-md);padding:var(--space-4);background-color:var(--color-surface-secondary)}.etree-endpoint-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-default)}.bandwidth-profile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.bandwidth-profile-warnings{margin-top:var(--space-3);padding:var(--space-3);background-color:var(--color-warning-50);border-left:3px solid var(--color-warning-500);border-radius:var(--radius-sm)}.bandwidth-profile-presets{margin-top:var(--space-4);display:flex;gap:var(--space-2);align-items:center}.optical-power-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.optical-power-budget{margin-top:var(--space-4);padding:var(--space-3);background-color:var(--color-surface-secondary);border-radius:var(--radius-md);font-size:var(--text-sm)}.power-budget-status{margin-left:var(--space-2);font-weight:var(--font-weight-semibold)}.power-budget-ok{color:var(--color-success-600)}.power-budget-marginal{color:var(--color-warning-600)}.power-budget-insufficient{color:var(--color-error-600)}.bgp-peer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.as-number-field{width:100%}.as-number-display{font-family:var(--font-mono);margin-top:var(--space-1)}.subnet-calculator{margin-top:var(--space-4);padding:var(--space-4);background-color:var(--color-info-50);border:1px solid var(--color-info-500);border-radius:var(--radius-md)}:root{--color-primary-50: #eff6ff;--color-primary-100: #dbeafe;--color-primary-200: #bfdbfe;--color-primary-300: #93c5fd;--color-primary-400: #60a5fa;--color-primary-500: #3b82f6;--color-primary-600: #2563eb;--color-primary-700: #1d4ed8;--color-primary-800: #1e40af;--color-primary-900: #1e3a8a;--color-success-50: #f0fdf4;--color-success-500: #22c55e;--color-success-600: #16a34a;--color-warning-50: #fffbeb;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-error-50: #fef2f2;--color-error-500: #ef4444;--color-error-600: #dc2626;--color-info-50: #eff6ff;--color-info-500: #3b82f6;--color-info-600: #2563eb;--color-neutral-50: #f9fafb;--color-neutral-100: #f3f4f6;--color-neutral-200: #e5e7eb;--color-neutral-300: #d1d5db;--color-neutral-400: #9ca3af;--color-neutral-500: #6b7280;--color-neutral-600: #4b5563;--color-neutral-700: #374151;--color-neutral-800: #1f2937;--color-neutral-900: #111827;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "Fira Code", "SF Mono", Monaco, "Cascadia Code", Consolas, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--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;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-focus: 0 0 0 2px var(--color-primary-500);--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);--z-dropdown: 1000;--z-sticky: 1100;--z-modal-backdrop: 1200;--z-modal: 1300;--z-popover: 1400;--z-tooltip: 1500;--z-toast: 1600;--color-surface-primary: #ffffff;--color-surface-secondary: #f9fafb;--color-surface-tertiary: #f3f4f6;--color-surface-overlay: rgba(0, 0, 0, .5);--color-border-default: #d1d5db;--color-border-hover: #9ca3af;--color-border-focus: #3b82f6;--color-border-error: #dc2626;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-text-disabled: #d1d5db;--color-text-on-primary: #ffffff;--color-text-link: #2563eb;--color-text-link-hover: #1d4ed8;--button-height-sm: 2rem;--button-height-md: 2.5rem;--button-height-lg: 3rem;--button-padding-x-sm: .75rem;--button-padding-x-md: 1rem;--button-padding-x-lg: 1.25rem;--button-font-size-sm: var(--text-sm);--button-font-size-md: var(--text-base);--button-font-size-lg: var(--text-lg);--modal-max-width-sm: 24rem;--modal-max-width-md: 32rem;--modal-max-width-lg: 48rem;--modal-max-width-xl: 64rem}[data-theme=dark]{--color-primary-500: #60a5fa;--color-primary-600: #3b82f6;--color-success-500: #34d399;--color-warning-500: #fbbf24;--color-error-500: #f87171;--color-info-500: #60a5fa;--color-surface-primary: #1f2937;--color-surface-secondary: #111827;--color-surface-tertiary: #0f172a;--color-surface-overlay: rgba(0, 0, 0, .7);--color-border-default: #4b5563;--color-border-hover: #6b7280;--color-border-focus: #60a5fa;--color-border-error: #f87171;--color-text-primary: #f9fafb;--color-text-secondary: #d1d5db;--color-text-tertiary: #9ca3af;--color-text-disabled: #6b7280;--color-text-on-primary: #ffffff;--color-text-link: #60a5fa;--color-text-link-hover: #93c5fd;--color-neutral-50: #1f2937;--color-neutral-100: #374151;--color-neutral-200: #4b5563;--color-neutral-900: #f9fafb}:root{font-family:var(--font-sans),Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:var(--line-height-normal);font-weight:var(--font-weight-normal);color-scheme:light dark;color:var(--color-text-primary);background-color:var(--color-neutral-50);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh}.app-container{max-width:1200px;margin:0 auto;padding:2rem}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #dee2e6}.header h1{font-size:1.5rem;color:var(--color-primary-500)}.card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:1rem}.card-header{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:#333}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#555}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #dee2e6;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 2px #1a73e833}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary{background-color:var(--color-primary-500);color:#fff}.btn-primary:hover{background-color:var(--color-primary-700)}.btn-primary:disabled{background-color:var(--color-neutral-400);cursor:not-allowed}.btn-secondary{background-color:var(--color-neutral-200);color:var(--color-neutral-600)}.btn-secondary:hover{background-color:var(--color-neutral-300)}.wizard-steps{display:flex;margin-bottom:2rem}.wizard-step{flex:1;text-align:center;padding:1rem;background:var(--color-neutral-200);color:var(--color-neutral-500);border-right:1px solid var(--color-neutral-300)}.wizard-step:first-child{border-radius:4px 0 0 4px}.wizard-step:last-child{border-radius:0 4px 4px 0;border-right:none}.wizard-step.active{background:var(--color-primary-500);color:#fff}.wizard-step.completed{background:var(--color-success-500);color:#fff}.wizard-step-number{display:inline-block;width:24px;height:24px;line-height:24px;border-radius:50%;background:#ffffff4d;margin-right:.5rem;font-size:.875rem}.validation-message{padding:.75rem 1rem;border-radius:4px;margin-bottom:.5rem;font-size:.875rem}.validation-message.error{background:var(--color-error-50);border-left:4px solid var(--color-error-500);color:var(--color-error-600)}.validation-message.warning{background:var(--color-warning-50);border-left:4px solid var(--color-warning-500);color:var(--color-warning-600)}.validation-message.info{background:var(--color-info-50);border-left:4px solid var(--color-primary-500);color:var(--color-primary-800)}.bom-table{width:100%;border-collapse:collapse}.bom-table th,.bom-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-neutral-200)}.bom-table th{background:var(--color-neutral-50);font-weight:600;color:var(--color-neutral-600)}.bom-table tr:hover{background:var(--color-neutral-50)}.bom-table .number{text-align:right}.pricing-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:1rem;background:var(--color-primary-50);border-radius:4px;margin-top:1rem}.pricing-item{text-align:center}.pricing-label{font-size:.875rem;color:var(--color-neutral-500)}.pricing-value{font-size:1.5rem;font-weight:600;color:var(--color-neutral-900)}.option-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.option-card{padding:1rem;border:2px solid var(--color-neutral-200);border-radius:8px;cursor:pointer;transition:all .2s;text-align:center}.option-card:hover{border-color:var(--color-primary-500);background:var(--color-primary-50)}.option-card.selected{border-color:var(--color-primary-500);background:var(--color-info-50)}.option-card-title{font-weight:600;margin-bottom:.5rem}.option-card-subtitle{font-size:.875rem;color:var(--color-neutral-500)}.toggle-group{display:flex;gap:.5rem}.toggle-option{flex:1;padding:.75rem;border:2px solid var(--color-neutral-200);border-radius:4px;text-align:center;cursor:pointer;transition:all .2s}.toggle-option:hover{border-color:var(--color-primary-500)}.toggle-option.selected{border-color:var(--color-primary-500);background:var(--color-primary-500);color:#fff}.bidi-diagram{background:var(--color-neutral-50);border:1px solid var(--color-neutral-200);border-radius:8px;padding:1rem;margin:1rem 0}.bidi-diagram-header{font-weight:600;color:var(--color-neutral-700);margin-bottom:1rem;text-align:center;font-size:.9rem}.bidi-diagram-content{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:1rem 0}.bidi-endpoint{flex:0 0 140px;text-align:center}.bidi-endpoint-label{font-size:.75rem;font-weight:600;color:var(--color-neutral-500);margin-bottom:.5rem;text-transform:uppercase}.bidi-endpoint-box{background:#fff;border:2px solid var(--color-primary-500);border-radius:8px;padding:.75rem}.bidi-endpoint.pop .bidi-endpoint-box{border-color:var(--color-success-500)}.bidi-endpoint.provider .bidi-endpoint-box{border-color:var(--color-warning-500)}.bidi-endpoint-box.warning{border-color:var(--color-error-500);background:var(--color-error-50)}.bidi-optic-name{font-size:.75rem;font-weight:600;color:var(--color-neutral-700);margin-bottom:.5rem}.bidi-wavelengths{display:flex;flex-direction:column;gap:.25rem;font-size:.7rem;font-family:monospace}.bidi-wavelengths .tx{color:var(--color-error-600)}.bidi-wavelengths .rx{color:var(--color-primary-600)}.bidi-sku-hint{font-size:.65rem;color:var(--color-neutral-400);margin-top:.5rem}.bidi-fiber{flex:1;display:flex;flex-direction:column;align-items:center;position:relative}.bidi-fiber-line{width:100%;display:flex;flex-direction:column;gap:.25rem;position:relative}.bidi-arrow{height:20px;position:relative;display:flex;align-items:center;justify-content:center}.bidi-arrow:before{content:"";position:absolute;left:0;right:0;height:3px;top:50%;transform:translateY(-50%)}.bidi-arrow.tx-arrow:before{background:linear-gradient(90deg,var(--color-error-600),var(--color-error-600))}.bidi-arrow.rx-arrow:before{background:linear-gradient(270deg,var(--color-primary-600),var(--color-primary-600))}.bidi-arrow:after{content:"";position:absolute;width:0;height:0;border:6px solid transparent;top:50%;transform:translateY(-50%)}.bidi-arrow.tx-arrow:after{right:0;border-left-color:var(--color-error-600);border-right:none}.bidi-arrow.rx-arrow:after{left:0;border-right-color:var(--color-primary-600);border-left:none}.wavelength-label{background:#fff;padding:0 .25rem;font-size:.6rem;font-family:monospace;color:var(--color-neutral-500);z-index:1}.bidi-fiber-label{font-size:.7rem;color:var(--color-neutral-500);margin-top:.5rem;text-align:center}.bidi-status{text-align:center;padding:.5rem;border-radius:4px;font-size:.8rem;font-weight:500;margin-top:.5rem}.bidi-status.success{background:var(--color-success-50);color:var(--color-success-600)}.bidi-status.error{background:var(--color-error-50);color:var(--color-error-600)}.bidi-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-neutral-200)}.bidi-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.7rem;color:var(--color-neutral-500)}.legend-color{width:12px;height:3px;border-radius:2px}.legend-color.tx{background:var(--color-error-600)}.legend-color.rx{background:var(--color-primary-600)}.optic-pair-display{background:var(--color-primary-50);border:1px solid var(--color-primary-200);border-radius:8px;padding:1rem;margin-top:1rem}.optic-pair-header{font-size:.8rem;font-weight:600;color:var(--color-primary-700);margin-bottom:.75rem}.optic-pair-items{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.optic-pair-item{background:#fff;border-radius:4px;padding:.5rem .75rem;font-size:.8rem}.optic-pair-item-label{font-size:.65rem;color:var(--color-neutral-500);text-transform:uppercase;margin-bottom:.25rem}.optic-pair-item-value{font-weight:600;color:var(--color-neutral-700)}.optic-pair-item-sku{font-size:.7rem;font-family:monospace;color:var(--color-neutral-500)}.site-tabs-container{margin-bottom:1rem}.site-tabs{display:flex;gap:.25rem;overflow-x:auto;padding-bottom:.25rem}.site-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--color-neutral-200);border-radius:8px 8px 0 0;cursor:pointer;transition:all .2s;white-space:nowrap;border:2px solid transparent;border-bottom:none}.site-tab:hover{background:var(--color-neutral-300)}.site-tab.active{background:#fff;border-color:var(--color-primary-500);border-bottom-color:#fff;margin-bottom:-2px;z-index:1}.site-tab.invalid{border-color:var(--color-warning-500)}.site-tab.invalid.active{border-color:var(--color-warning-500);border-bottom-color:#fff}.site-tab-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#0000001a;font-size:.8rem;font-weight:600}.site-tab.active .site-tab-number{background:var(--color-primary-500);color:#fff}.site-tab-name{font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis}.site-tab-warning{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--color-warning-500);color:#fff;font-size:.75rem;font-weight:700}.site-tab-actions{display:flex;gap:.25rem;margin-left:.5rem}.site-tab-action{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;border:none;background:var(--color-neutral-200);cursor:pointer;font-size:.75rem;font-weight:700;color:var(--color-neutral-500)}.site-tab-action:hover{background:var(--color-neutral-300)}.site-tab-action.remove:hover{background:var(--color-error-50);color:var(--color-error-600)}.site-tab.add-site{background:transparent;border:2px dashed var(--color-neutral-300);color:var(--color-neutral-500)}.site-tab.add-site:hover{border-color:var(--color-primary-500);color:var(--color-primary-500);background:var(--color-primary-50)}.site-config-form .form-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-neutral-200)}.site-config-form .form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.site-config-form h3{font-size:1rem;color:var(--color-neutral-700);margin-bottom:1rem}.site-config-form .info-box{padding:1rem;background:var(--color-primary-50);border-radius:4px;margin-top:1rem}.site-config-form .provider-config{margin-top:1rem;padding:1rem;background:var(--color-warning-50);border-radius:4px;border:1px solid var(--color-warning-500)}.gbb-comparison{padding:0}.gbb-discount-banner{background:linear-gradient(135deg,var(--color-success-500) 0%,var(--color-success-600) 100%);color:#fff;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-weight:600;text-align:center}.gbb-discount-banner .discount-detail{opacity:.9;font-weight:400;margin-left:.5rem}.gbb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.gbb-card{border:2px solid var(--color-neutral-200);border-radius:12px;overflow:hidden;transition:all .2s}.gbb-card.selectable{cursor:pointer}.gbb-card.selectable:hover{border-color:var(--color-neutral-400);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.gbb-card.selected{box-shadow:0 4px 12px #1a73e833}.gbb-card-header{padding:1rem;color:#fff;text-align:center}.gbb-tier-label{font-size:1.25rem;font-weight:700}.gbb-recommended{font-size:.7rem;background:#fff3;padding:.25rem .5rem;border-radius:4px;margin-top:.5rem;display:inline-block}.gbb-pricing{padding:1rem;background:var(--color-neutral-50)}.gbb-price-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--color-neutral-200)}.gbb-price-row:last-child{border-bottom:none}.gbb-price-label{color:var(--color-neutral-500);font-size:.85rem}.gbb-price-value{font-weight:700;font-size:1.1rem;color:var(--color-neutral-900)}.gbb-price-unit{font-size:.75rem;font-weight:400;color:var(--color-neutral-500)}.gbb-original-price{font-size:.8rem;color:var(--color-neutral-400);text-decoration:line-through;margin-left:.5rem}.gbb-features{padding:1rem}.gbb-features-header{font-size:.8rem;color:var(--color-neutral-500);margin-bottom:.5rem;text-transform:uppercase}.gbb-features ul{list-style:none;font-size:.85rem}.gbb-features li{padding:.25rem 0;color:var(--color-neutral-600)}.gbb-features li:before{content:"✓";color:var(--color-success-500);margin-right:.5rem}.gbb-summary{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-neutral-200)}.gbb-summary-row{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.9rem;color:var(--color-neutral-500)}.gbb-summary-row.highlight{color:var(--color-success-600);font-weight:600}.proposal-list{display:flex;flex-direction:column;gap:1rem}.proposal-list-item{background:#fff;border-radius:8px;padding:1rem 1.25rem;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .2s;border:2px solid transparent}.proposal-list-item:hover{border-color:var(--color-primary-500);box-shadow:0 4px 12px #0000001a}.proposal-list-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.proposal-list-name{font-size:1.1rem;font-weight:600;margin:0;color:var(--color-neutral-900)}.proposal-list-customer{color:var(--color-neutral-500);font-size:.9rem}.proposal-list-badges{display:flex;gap:.5rem}.proposal-status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.proposal-status-badge.valid{background:var(--color-success-50);color:var(--color-success-600)}.proposal-status-badge.invalid{background:var(--color-warning-50);color:var(--color-warning-600)}.proposal-status-badge.status{background:var(--color-neutral-200);color:var(--color-neutral-600);text-transform:capitalize}.proposal-list-details{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.proposal-list-meta{display:flex;gap:1rem;font-size:.85rem;color:var(--color-neutral-500)}.proposal-list-meta .discount-badge{background:var(--color-success-50);color:var(--color-success-600);padding:.125rem .5rem;border-radius:4px;font-weight:500}.proposal-list-pricing{display:flex;gap:1rem}.pricing-tier{text-align:center;padding:.5rem 1rem;background:var(--color-neutral-50);border-radius:4px}.pricing-tier .tier-label{display:block;font-size:.7rem;color:var(--color-neutral-500);text-transform:uppercase}.pricing-tier .tier-value{font-weight:600;color:var(--color-neutral-700)}.pricing-tier .tier-value.highlight{color:var(--color-primary-500)}.proposal-list-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-neutral-200)}.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.site-card{border:2px solid var(--color-neutral-200);border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s}.site-card:hover{border-color:var(--color-primary-500);background:var(--color-neutral-50)}.site-card.active{border-color:var(--color-primary-500);background:var(--color-info-50)}.site-card.invalid{border-color:var(--color-warning-500)}.site-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.site-card-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--color-primary-500);color:#fff;font-size:.75rem;font-weight:600}.site-card-name{font-weight:600;color:var(--color-neutral-900);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-card-warning{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--color-warning-500);color:#fff;font-size:.7rem;font-weight:700}.site-card-details{display:flex;gap:.5rem;font-size:.8rem;color:var(--color-neutral-500);flex-wrap:wrap}.site-card-details span{background:var(--color-neutral-100);padding:.125rem .5rem;border-radius:4px;text-transform:capitalize}.review-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-neutral-200)}.review-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.review-section h3{font-size:1rem;color:var(--color-neutral-700);margin-bottom:.75rem}.review-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.mode-switcher{display:flex;gap:.5rem;padding:.5rem;background:var(--color-neutral-100);border-radius:8px;margin-bottom:1rem}.mode-switcher button{flex:1;padding:.75rem;border:none;border-radius:6px;background:transparent;color:var(--color-neutral-500);font-weight:500;cursor:pointer;transition:all .2s}.mode-switcher button:hover{background:#ffffff80}.mode-switcher button.active{background:#fff;color:var(--color-primary-500);box-shadow:0 1px 3px #0000001a}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-50) 0%,var(--color-primary-100) 100%);padding:1rem}.login-card{width:100%;max-width:400px;padding:2rem;text-align:center}.login-card h2{color:var(--color-neutral-900);margin-bottom:.5rem}.login-card form{text-align:left}.login-card .form-group{margin-bottom:1rem}.login-card .form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--color-neutral-700);margin-bottom:.5rem}.login-card .form-group input{width:100%;padding:.75rem;border:1px solid var(--color-neutral-300);border-radius:6px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.login-card .form-group input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #1a73e81a}.login-card .form-group input:disabled{background:var(--color-neutral-50);cursor:not-allowed}.login-divider{display:flex;align-items:center;margin:1.5rem 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-neutral-200)}.login-divider span{padding:0 1rem;color:var(--color-neutral-500);font-size:.875rem}.sso-btn{width:100%}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem}.spinner{width:40px;height:40px;border:3px solid var(--color-neutral-200);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.header-left{display:flex;flex-direction:column;gap:.25rem}.header-left h1{margin:0}.header-right{display:flex;align-items:center;gap:1rem}.user-info{font-size:.875rem;color:var(--color-neutral-700)}.user-role{color:var(--color-neutral-500);font-size:.75rem;margin-left:.25rem}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}@media (max-width: 1024px){.mode-switcher{flex-wrap:wrap}.mode-switcher button{min-width:calc(50% - .25rem)}.header{flex-direction:column;align-items:flex-start}.header-right{width:100%;justify-content:space-between}.bidi-diagram-content{flex-direction:column;gap:1rem}.bidi-endpoint{flex:0 0 auto;width:100%;max-width:200px}.bidi-fiber{transform:rotate(90deg);width:150px;margin:1rem 0}.dashboard-grid{grid-template-columns:1fr}.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.app-container{padding:1rem}.wizard-steps{flex-direction:column}.wizard-step{border-right:none;border-bottom:1px solid var(--color-neutral-300)}.wizard-step:first-child{border-radius:4px 4px 0 0}.wizard-step:last-child{border-radius:0 0 4px 4px;border-bottom:none}.form-row,.option-cards{grid-template-columns:1fr}.toggle-group{flex-direction:column}.site-tabs{flex-direction:row;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:thin;padding-bottom:.5rem}.site-tabs::-webkit-scrollbar{height:4px}.site-tabs::-webkit-scrollbar-track{background:var(--color-neutral-200);border-radius:2px}.site-tabs::-webkit-scrollbar-thumb{background:var(--color-neutral-400);border-radius:2px}.site-tab{flex-shrink:0;border-radius:8px 8px 0 0}.gbb-grid{grid-template-columns:1fr}.proposal-list-details{flex-direction:column;align-items:flex-start}.proposal-list-pricing{width:100%;justify-content:space-between}.proposal-list-meta{flex-wrap:wrap}.bom-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.bom-table{min-width:600px}.pricing-summary{grid-template-columns:1fr;gap:.75rem}.review-grid,.sites-grid,.optic-pair-items,.dashboard-stats{grid-template-columns:1fr}.dashboard-quick-actions{flex-direction:column}.global-search-container{position:static;width:100%}.global-search-dropdown{position:fixed;top:auto;left:0;right:0;bottom:0;max-height:50vh;border-radius:12px 12px 0 0;box-shadow:0 -4px 20px #00000026}.card[style*="position: fixed"]{width:100%!important;max-width:100%!important;max-height:100vh!important;border-radius:0!important}.bulk-actions-bar{flex-direction:column;gap:.75rem}.bulk-actions-bar>div{width:100%;justify-content:space-between}.bidi-diagram-content{flex-direction:column;align-items:center}.bidi-endpoint{flex:0 0 auto;width:100%;max-width:180px}.bidi-fiber{width:100%;max-width:200px;transform:rotate(90deg);height:80px;margin:2rem 0}.login-card{padding:1.5rem}}@media (max-width: 480px){.app-container{padding:.75rem}.card{padding:1rem;border-radius:6px}.card-header{font-size:1rem}.btn{width:100%;text-align:center}.btn+.btn{margin-top:.5rem}.button-group,[style*="display: flex"][style*=gap]>.btn{flex-direction:column}.header h1{font-size:1.25rem}.header-right{flex-direction:column;align-items:flex-start;gap:.5rem}.pricing-tier{padding:.375rem .5rem}.pricing-tier .tier-value{font-size:.9rem}.gbb-card-header{padding:.75rem}.gbb-tier-label{font-size:1rem}.gbb-pricing{padding:.75rem}.gbb-price-value{font-size:1rem}.site-tab{padding:.5rem .75rem}.site-tab-name{max-width:100px}.proposal-list-item{padding:.875rem 1rem}.proposal-list-name{font-size:1rem}.proposal-list-actions{flex-direction:column}.proposal-list-actions .btn{width:100%}.wizard-step{padding:.75rem;font-size:.875rem}.wizard-step-number{width:20px;height:20px;line-height:20px;font-size:.75rem}.form-group input,.form-group select,.form-group textarea{padding:.625rem;font-size:16px}.validation-message{padding:.625rem .875rem;font-size:.8125rem}.bom-table th,.bom-table td{padding:.5rem;font-size:.8125rem}.mode-switcher{padding:.375rem;gap:.375rem}.mode-switcher button{padding:.5rem;font-size:.8125rem;min-width:100%}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.global-search-input{font-size:16px}}@media (hover: none) and (pointer: coarse){.btn,.site-tab{min-height:44px}.option-card{min-height:60px}.toggle-option{min-height:44px}.option-card:hover,.toggle-option:hover,.site-card:hover,.proposal-list-item:hover{transform:none;box-shadow:inherit}}@media (max-width: 896px) and (orientation: landscape){.wizard-steps{flex-direction:row}.wizard-step{border-right:1px solid var(--color-neutral-300);border-bottom:none}.wizard-step:first-child{border-radius:4px 0 0 4px}.wizard-step:last-child{border-radius:0 4px 4px 0;border-right:none}.gbb-grid{grid-template-columns:repeat(3,1fr)}}@media print{.header-right,.mode-switcher,.wizard-steps,.btn,.site-tab-actions,.proposal-list-actions,.bulk-actions-bar{display:none!important}.app-container{max-width:none;padding:0}.card{box-shadow:none;border:1px solid var(--color-neutral-200);page-break-inside:avoid}.bom-table{font-size:10pt}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
