:root {
  --primary: #667eea;
  --primary-dark: #764ba2;
  --secondary: #3498db;
  --success: #27ae60;
  --danger: #e74c3c;
  --warning: #f39c12;
  --info: #9b59b6;
  --bg-main: #f5f5f5;
  --bg-card: #ffffff;
  --bg-hover: #f8f9fa;
  --text-primary: #333333;
  --text-secondary: #666666;
  --text-muted: #999999;
  --border: rgba(0,0,0,0.05);
  --shadow-sm: 0 2px 5px rgba(0,0,0,0.05);
  --shadow-md: 0 10px 30px rgba(0,0,0,0.08);
  --shadow-lg: 0 20px 50px rgba(0,0,0,0.1);
  --gradient-primary: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  --gradient-success: linear-gradient(135deg, #d4edda 0%, #c3e6cb 100%);
  --gradient-danger: linear-gradient(135deg, #fee5e5 0%, #fff5f5 100%);
  --gradient-info: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-full: 50px;
  --transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
}

[data-theme="dark"] {
  --primary: #8b9ff4;
  --primary-dark: #9e7bc9;
  --bg-main: #0f0f0f;
  --bg-card: #1a1a1a;
  --bg-hover: #252525;
  --text-primary: #e0e0e0;
  --text-secondary: #b0b0b0;
  --text-muted: #808080;
  --border: rgba(255,255,255,0.1);
  --shadow-sm: 0 2px 5px rgba(0,0,0,0.3);
  --shadow-md: 0 10px 30px rgba(0,0,0,0.5);
  --shadow-lg: 0 20px 50px rgba(0,0,0,0.7);
}

[data-theme="green"] {
  --primary: #27ae60;
  --primary-dark: #229954;
  --secondary: #2ecc71;
  --gradient-primary: linear-gradient(135deg, #27ae60 0%, #229954 100%);
}

[data-theme="orange"] {
  --primary: #f39c12;
  --primary-dark: #e67e22;
  --secondary: #e74c3c;
  --gradient-primary: linear-gradient(135deg, #f39c12 0%, #e67e22 100%);
}

[data-theme="red"] {
  --primary: #e74c3c;
  --primary-dark: #c0392b;
  --secondary: #c0392b;
  --gradient-primary: linear-gradient(135deg, #e74c3c 0%, #c0392b 100%);
}

* {margin:0;padding:0;box-sizing:border-box}
body {font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg-main);color:var(--text-primary);line-height:1.6;transition:background-color 0.3s,color 0.3s}
.container {max-width:1200px;margin:0 auto;padding:20px}
.header {text-align:center;margin-bottom:40px;padding:40px 20px;background:var(--gradient-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);color:#fff}
.header h1 {margin-bottom:10px;font-size:48px;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,0.1)}
.header p {font-size:20px;font-weight:500;opacity:0.95}
.header .subtitle {font-size:16px;opacity:0.85;margin-top:5px}
.input-section {background:var(--bg-card);padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:30px;border:1px solid var(--border);transition:var(--transition)}
.form-row {display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.form-group {position:relative}
.form-group label {display:block;margin-bottom:8px;font-weight:600;color:var(--text-primary);font-size:15px}
.form-group input,.form-group textarea,.form-group select {width:100%;padding:14px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:16px;transition:var(--transition);background:var(--bg-hover);font-family:inherit;color:var(--text-primary)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus {outline:none;border-color:var(--primary);background:var(--bg-card);box-shadow:0 0 0 3px rgba(102,126,234,0.1)}
.form-group input.error,.form-group textarea.error,.form-group select.error {border-color:var(--danger);background:var(--gradient-danger)}
.form-select {cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 16px center;background-size:20px;padding-right:45px}
.field-description {font-size:13px;color:var(--text-secondary);margin-top:5px;font-style:italic}
.saved-message {background:var(--gradient-success);color:#155724;padding:12px 20px;border-radius:var(--radius-sm);margin-bottom:20px;text-align:center;font-weight:500;animation:slideDown 0.3s ease-out;border:1px solid #c3e6cb}
@keyframes slideDown {from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.form-group textarea {resize:vertical;min-height:100px}
.form-info {text-align:center;margin:10px 0 0;padding:15px;background:var(--bg-hover);border-radius:var(--radius-sm)}
.form-info small {color:var(--text-secondary);font-size:14px}
.form-footer {margin-top:25px}
.remember-data {margin-bottom:20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:15px}
.checkbox-label {display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:15px;color:var(--text-primary);padding:12px 20px;background:var(--bg-hover);border-radius:var(--radius-sm);transition:var(--transition)}
.checkbox-label:hover {background:var(--bg-card);transform:translateY(-1px)}
.checkbox-input {width:20px;height:20px;cursor:pointer;accent-color:var(--primary)}
.checkbox-label span {font-weight:500}
.clear-data-btn {background:var(--danger);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;cursor:pointer;transition:var(--transition);font-weight:500}
.clear-data-btn:hover {background:#c0392b;transform:translateY(-1px);box-shadow:0 2px 5px rgba(231,76,60,0.3)}
.submit-btn {background:var(--gradient-primary);color:#fff;padding:16px 40px;border:none;border-radius:var(--radius-full);font-size:18px;font-weight:700;cursor:pointer;transition:var(--transition);width:100%;text-transform:uppercase;letter-spacing:1px;box-shadow:0 4px 15px rgba(102,126,234,0.3);position:relative;overflow:hidden}
.submit-btn:hover {transform:translateY(-2px);box-shadow:0 6px 20px rgba(102,126,234,0.4)}
.submit-btn:disabled {background:linear-gradient(135deg,#95a5a6 0%,#7f8c8d 100%);cursor:not-allowed;transform:none;box-shadow:none}
.loading {text-align:center;padding:60px;font-size:20px;color:var(--primary);font-weight:500;position:relative;overflow:hidden}
.error {background:var(--gradient-danger);color:#c00;padding:20px;border-radius:var(--radius-sm);margin-bottom:20px;border:1px solid #fcc;font-weight:500}
.proposals-list {display:flex;flex-direction:column;gap:30px;margin-top:40px;max-width:1000px;margin-left:auto;margin-right:auto}
.proposal-card {background:var(--bg-card);padding:0;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:var(--transition);position:relative;overflow:hidden;border:1px solid var(--border);width:100%}
.delete-proposal-btn {position:absolute;top:15px;right:15px;background:rgba(231,76,60,0.1);color:var(--danger);border:none;width:32px;height:32px;border-radius:50%;font-size:18px;font-weight:bold;cursor:pointer;transition:var(--transition);z-index:10;display:flex;align-items:center;justify-content:center;opacity:0.7}
.delete-proposal-btn:hover {background:var(--danger);color:#fff;opacity:1;transform:scale(1.1);box-shadow:0 4px 12px rgba(231,76,60,0.3)}
.proposal-card::before {content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#3498db,#2ecc71,#e74c3c,#f39c12);background-size:300% 100%;animation:gradientShift 3s ease infinite}
@keyframes gradientShift {0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.proposal-header {background:var(--gradient-primary);padding:30px 40px;margin:0;display:flex;align-items:center;gap:25px;color:#fff}
.proposal-emoji {font-size:60px;filter:drop-shadow(0 4px 8px rgba(0,0,0,0.2));animation:bounce 2s infinite}
@keyframes bounce {0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.proposal-header h3 {color:#fff;margin:0;font-size:26px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,0.1)}
.proposal-price {background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);padding:25px 40px;margin:0;color:#fff}
.price-main {display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}
.price-label {font-weight:500;color:#fff;opacity:0.9;font-size:18px}
.price-value {font-size:32px;font-weight:800;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,0.2)}
.price-financing {display:flex;flex-direction:column;gap:8px;padding-top:15px;border-top:1px solid rgba(255,255,255,0.3)}
.financing-info {font-size:14px;color:rgba(255,255,255,0.95);font-weight:500;display:flex;align-items:center;gap:8px}
.grants-info {font-size:13px;color:rgba(255,255,255,0.85);font-style:italic;display:flex;align-items:center;gap:8px}
.financing-tooltip {margin-top:10px;padding:10px 15px;background:rgba(0,0,0,0.2);border-radius:var(--radius-sm);font-size:12px;line-height:1.4}
.financing-tooltip p {margin:3px 0;color:rgba(255,255,255,0.9)}
.proposal-main-content {display:grid;grid-template-columns:1fr 1fr;gap:30px;padding:30px 40px}
.proposal-section {margin:0;padding:25px;background:var(--bg-hover);border-radius:var(--radius-md);border-left:4px solid var(--secondary);transition:var(--transition)}
.proposal-section:hover {transform:translateX(5px);box-shadow:var(--shadow-sm)}
.proposal-section:nth-child(1){border-left-color:#3498db}
.proposal-section:nth-child(2){border-left-color:#2ecc71}
.proposal-section:nth-child(3){border-left-color:#e74c3c}
.proposal-section:nth-child(4){border-left-color:#f39c12}
.proposal-section:nth-child(5){border-left-color:#9b59b6;grid-column:1/-1}
.proposal-section h4 {color:var(--text-primary);margin:0 0 15px;font-size:18px;font-weight:700;display:flex;align-items:center;gap:10px}
.proposal-section p {margin:0;font-size:16px;line-height:1.6;color:var(--text-secondary)}
.proposal-section:has(.metrics-list){grid-column:1/-1}
.metrics-list {list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}
.metrics-list li {background:var(--bg-card);padding:15px 20px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:15px;box-shadow:var(--shadow-sm);transition:var(--transition);display:flex;align-items:center;gap:10px}
.metrics-list li:hover {transform:translateY(-2px);box-shadow:var(--shadow-md)}
.metrics-list li:before {content:"📈";font-size:20px}
.scope-section {padding:30px 40px;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:30px}
.scope-included,.scope-excluded {background:var(--bg-card);padding:25px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:var(--transition)}
.scope-included:hover,.scope-excluded:hover {transform:translateY(-3px);box-shadow:var(--shadow-md)}
.scope-included {border-top:4px solid var(--success)}
.scope-excluded {border-top:4px solid var(--danger)}
.scope-included h4,.scope-excluded h4 {margin:0 0 20px;font-size:18px;color:var(--text-primary);font-weight:700}
.scope-list {list-style:none;padding:0;margin:0}
.scope-list li {padding:12px 0 12px 30px;position:relative;font-size:15px;color:var(--text-secondary);border-bottom:1px solid var(--border)}
.scope-list li:last-child {border-bottom:none}
.scope-list li:before {content:"✓";position:absolute;left:0;top:12px;color:var(--success);font-weight:bold;font-size:18px}
.scope-list.excluded li:before {content:"✗";color:var(--danger)}
.expand-btn {width:calc(100% - 80px);margin:30px 40px 40px;padding:20px 40px;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-full);font-size:18px;font-weight:700;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden;text-transform:uppercase;letter-spacing:1px}
.expand-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(102,126,234,0.4)}
.expand-btn:disabled {background:linear-gradient(135deg,#95a5a6 0%,#7f8c8d 100%);cursor:not-allowed}
.expand-btn.expanded {background:linear-gradient(135deg,#e74c3c 0%,#c0392b 100%)}
.expanded-details {margin-top:30px;padding:0;background:transparent;border:none;animation:fadeInUp 0.5s ease-out}
@keyframes fadeInUp {from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.expanded-section {background:var(--bg-card);padding:25px;margin-bottom:20px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:var(--transition)}
.expanded-section:hover {transform:translateY(-2px);box-shadow:var(--shadow-md)}
.expanded-section h4 {color:var(--text-primary);margin-bottom:20px;font-size:20px;font-weight:600;border-bottom:3px solid;border-image:linear-gradient(90deg,#3498db,#2ecc71) 1;padding-bottom:12px}
.phases-list {position:relative;padding-left:30px}
.phases-list::before {content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#3498db,#2ecc71)}
.phase-item {background:var(--bg-hover);padding:20px;margin-bottom:20px;border-radius:var(--radius-sm);position:relative;border:2px solid transparent;background-clip:padding-box;transition:var(--transition)}
.phase-item::before {content:'⚡';position:absolute;left:-42px;top:20px;width:24px;height:24px;background:var(--bg-card);border:3px solid #3498db;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}
.phase-item:hover {background:var(--bg-card);box-shadow:0 5px 15px rgba(52,152,219,0.2);transform:translateX(5px)}
.phase-duration {background:var(--gradient-primary);color:#fff;padding:6px 16px;border-radius:20px;font-size:13px;font-weight:600;display:inline-block;margin-top:10px}
.risks-grid {display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}
.risk-item {background:var(--gradient-danger);padding:20px;border-radius:var(--radius-md);border:2px solid #fee5e5;position:relative;overflow:hidden;transition:var(--transition)}
.risk-item::before {content:'⚠️';position:absolute;top:-20px;right:-20px;font-size:80px;opacity:0.1}
.risk-item:hover {transform:translateY(-3px);box-shadow:0 10px 20px rgba(231,76,60,0.1);border-color:var(--danger)}
.risk-item h5 {color:var(--danger);margin-bottom:12px;font-size:18px;font-weight:600}
.risk-mitigation {background:#d4edda;padding:12px;border-radius:var(--radius-sm);margin-top:12px;border-left:4px solid var(--success)}
.use-cases-list {display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:15px;list-style:none;padding:0}
.use-cases-list li {background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);padding:20px 20px 20px 50px;border-radius:var(--radius-sm);position:relative;min-height:80px;display:flex;align-items:center;transition:var(--transition);font-weight:500;color:var(--text-primary)}
.use-cases-list li:hover {transform:translateY(-3px);box-shadow:var(--shadow-md)}
.use-cases-list li:before {content:'💼';position:absolute;left:15px;font-size:24px}
.expanded-section:has(>p) p {background:var(--bg-hover);padding:20px;border-radius:var(--radius-sm);line-height:1.8;white-space:pre-wrap;border-left:4px solid #3498db;margin:0}
.next-steps-list {display:flex;flex-wrap:wrap;gap:15px;padding:0;margin:0;list-style:none;counter-reset:step-counter}
.next-steps-list li {flex:1;min-width:250px;background:var(--gradient-primary);color:#fff;padding:20px;border-radius:var(--radius-sm);position:relative;font-weight:500;transition:var(--transition)}
.next-steps-list li:hover {transform:translateY(-3px);box-shadow:0 10px 25px rgba(102,126,234,0.3)}
.next-steps-list li::before {content:counter(step-counter);counter-increment:step-counter;position:absolute;top:-10px;left:20px;background:var(--bg-card);color:var(--primary);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:bold;box-shadow:0 2px 5px rgba(0,0,0,0.2)}
.expanded-section:nth-child(2) ;border-left-color:#1976d2}
.mermaid-container {background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);padding:30px;border-radius:var(--radius-md);margin-top:15px;box-shadow:inset 0 2px 4px rgba(0,0,0,0.06);overflow-x:auto}
.mermaid {text-align:center;min-height:200px}
.mermaid svg {max-width:100%;height:auto}
.expanded-section:has(>p:contains("Equipo requerido")) p {background:linear-gradient(135deg,#ffecd2 0%,#fcb69f 100%);border-left-color:#ff6b6b}
.company-analysis {background:var(--bg-card);padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:40px;border:1px solid var(--border)}
.company-analysis h2 {color:var(--text-primary);margin-bottom:30px;padding-bottom:15px;border-bottom:3px solid;border-image:linear-gradient(90deg,#3498db,#2ecc71) 1;font-size:32px}
.analysis-content {margin-top:20px}
.analysis-section {margin-bottom:30px}
.analysis-section h3 {color:var(--secondary);margin-bottom:15px;font-size:24px}
.analysis-section h4 {color:var(--text-primary);margin-bottom:10px;font-size:18px}
.analysis-grid {display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:25px;margin:25px 0}
.analysis-item {padding:25px;background:linear-gradient(135deg,var(--bg-hover) 0%,#e9ecef 100%);border-radius:var(--radius-md);border-left:4px solid var(--secondary);transition:var(--transition)}
.analysis-item:hover {transform:translateY(-3px);box-shadow:var(--shadow-md)}
.analysis-item h4 {color:var(--secondary);margin-bottom:12px;font-size:16px;text-transform:uppercase;letter-spacing:0.5px}
.analysis-item p {color:var(--text-secondary);line-height:1.6;font-size:15px}
.insights-list {list-style:none;padding-left:0}
.insights-list li {padding:12px 0 12px 30px;color:var(--text-secondary);position:relative;font-size:16px;border-bottom:1px solid var(--border)}
.insights-list li:last-child {border-bottom:none}
.insights-list li:before {content:"💡";position:absolute;left:0;font-size:20px}
.progress-indicator {position:fixed;bottom:20px;left:20px;background:var(--bg-card);border-radius:15px;box-shadow:var(--shadow-lg);padding:20px;min-width:320px;max-width:420px;z-index:1000;transition:var(--transition);border:1px solid var(--border)}
.progress-header {display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;cursor:pointer}
.progress-header h4 {margin:0;color:var(--text-primary);font-size:16px;font-weight:600}
.progress-toggle {background:none;border:none;cursor:pointer;font-size:20px;color:var(--secondary);transition:transform 0.3s}
.progress-toggle.collapsed {transform:rotate(180deg)}
.progress-content {max-height:300px;overflow-y:auto;transition:max-height 0.3s ease}
.progress-content.collapsed {max-height:0;overflow:hidden}
.progress-item {display:flex;align-items:center;padding:10px 0;color:var(--text-secondary);font-size:14px;border-bottom:1px solid var(--border)}
.progress-item:last-child {border-bottom:none}
.progress-item.active {color:var(--secondary);font-weight:600}
.progress-item.completed {color:var(--success)}
.progress-icon {margin-right:10px;font-size:18px}
.progress-spinner {animation:spin 1s linear infinite}
@keyframes spin {from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.executive-summary {background:var(--bg-card);padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin:40px auto;max-width:1000px;border:1px solid var(--border)}
.executive-summary h2 {color:var(--text-primary);margin-bottom:30px;text-align:center;font-size:32px;border-bottom:3px solid;border-image:linear-gradient(90deg,#3498db,#2ecc71) 1;padding-bottom:15px}
.summary-content {margin-top:30px}
.summary-section {margin-bottom:35px}
.summary-section h3 {color:var(--secondary);margin-bottom:15px;font-size:22px;display:flex;align-items:center;gap:10px}
.summary-section p {color:var(--text-secondary);line-height:1.8;font-size:16px;background:var(--bg-hover);padding:20px;border-radius:var(--radius-sm);border-left:4px solid var(--secondary)}
.recommendations-list {list-style:none;padding:0}
.recommendations-list li {background:linear-gradient(135deg,var(--bg-hover) 0%,#e9ecef 100%);padding:20px 20px 20px 50px;margin-bottom:15px;border-radius:var(--radius-sm);border-left:4px solid #2ecc71;color:var(--text-secondary);font-size:16px;position:relative}
.recommendations-list li:before {content:'💡';position:absolute;left:15px;font-size:24px}
.summary-grid {display:grid;grid-template-columns:1fr 1fr;gap:30px;margin:30px 0}
.summary-card {background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);padding:30px;border-radius:15px;transition:var(--transition)}
.summary-card:hover {transform:translateY(-3px)}
.summary-card h4 {color:var(--text-primary);margin-bottom:15px;font-size:20px;display:flex;align-items:center;gap:10px}
.quick-wins {border-top:4px solid #f39c12}
.quick-wins ul {list-style:none;padding:0}
.quick-wins li {padding:12px 0 12px 25px;position:relative;color:var(--text-secondary);font-size:15px}
.quick-wins li:before {content:'✅';position:absolute;left:0}
.long-term {border-top:4px solid #9b59b6}
.long-term p {color:var(--text-secondary);line-height:1.8;font-size:15px}
.next-steps {background:var(--gradient-primary);padding:30px;border-radius:15px;color:#fff;text-align:center;position:relative;overflow:hidden}
.next-steps .step-animation {position:absolute;font-size:28px;opacity:0;pointer-events:none}
.next-steps .step-1 {animation:walkPath1 10s infinite ease-in-out}
.next-steps .step-2 {animation:walkPath2 12s infinite ease-in-out 3s}
.next-steps .step-3 {animation:walkPath3 15s infinite ease-in-out 6s}
@keyframes walkPath1 {0%{left:-30px;bottom:10px;opacity:0;transform:rotate(15deg)}15%{opacity:0.4}50%{left:40%;bottom:50%;opacity:0.2;transform:rotate(-5deg)}85%{opacity:0.1}100%{left:105%;bottom:80%;opacity:0;transform:rotate(25deg)}}
@keyframes walkPath2 {0%{right:-30px;top:20px;opacity:0;transform:rotate(-20deg) scale(0.7)}20%{opacity:0.3}60%{right:60%;top:60%;opacity:0.15;transform:rotate(10deg) scale(1.1)}90%{opacity:0.05}100%{right:110%;top:90%;opacity:0;transform:rotate(-30deg) scale(0.5)}}
@keyframes walkPath3 {0%{left:20%;top:-30px;opacity:0;transform:rotate(45deg)}25%{opacity:0.25}50%{left:70%;top:40%;opacity:0.15;transform:rotate(-15deg)}75%{opacity:0.08}100%{left:120%;top:100%;opacity:0;transform:rotate(60deg)}}
.next-steps h3 {color:#fff;margin-bottom:20px;position:relative;z-index:1}
.next-steps p {background:rgba(255,255,255,0.1);padding:20px;border-radius:var(--radius-sm);border:2px solid rgba(255,255,255,0.2);color:#fff;font-size:16px;line-height:1.8;position:relative;z-index:1}
.made-with-footer {position:fixed;bottom:20px;right:20px;background:rgba(255,255,255,0.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:8px 16px;border-radius:var(--radius-full);box-shadow:0 4px 20px rgba(0,0,0,0.1);font-size:12px;color:var(--text-secondary);text-decoration:none;display:flex;align-items:center;gap:8px;transition:var(--transition);z-index:1000;border:1px solid var(--border)}
.made-with-footer:hover {transform:translateY(-2px);box-shadow:0 6px 25px rgba(0,0,0,0.15);background:rgba(255,255,255,0.95);color:var(--text-secondary);text-decoration:none}
.made-with-footer::before {content:'✨';font-size:16px;animation:sparkle 2s ease-in-out infinite}
.made-with-footer .heart {color:var(--danger);animation:heartbeat 1.5s ease-in-out infinite}
.made-with-footer .brand {background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}
@keyframes sparkle {0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.7;transform:scale(1.2)}}
@keyframes heartbeat {0%,100%{transform:scale(1)}10%,30%{transform:scale(1.1)}20%{transform:scale(1.15)}}
.proposals-header {display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;flex-wrap:wrap;gap:20px}
.download-section {display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.download-info {font-size:14px;color:var(--text-secondary);font-style:italic;margin:0;text-align:right;transition:var(--transition)}
.download-info.all-expanded {color:var(--success);font-weight:600;font-style:normal}
.download-actions {display:flex;gap:10px;flex-wrap:wrap}
.view-btn {background:linear-gradient(135deg,#9b59b6 0%,#8e44ad 100%);color:#fff;padding:12px 25px;border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:var(--transition);box-shadow:0 4px 15px rgba(155,89,182,0.3)}
.view-btn:hover {transform:translateY(-2px);box-shadow:0 6px 20px rgba(155,89,182,0.4);color:#fff;text-decoration:none}
.download-btn {background:linear-gradient(135deg,#27ae60 0%,#229954 100%);color:#fff;padding:12px 25px;border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:var(--transition);box-shadow:0 4px 15px rgba(39,174,96,0.3)}
.download-btn:hover {transform:translateY(-2px);box-shadow:0 6px 20px rgba(39,174,96,0.4);color:#fff;text-decoration:none}
.copy-link-btn {background:linear-gradient(135deg,#3498db 0%,#2980b9 100%);color:#fff;padding:12px 25px;border:none;border-radius:var(--radius-full);font-weight:600;font-size:15px;cursor:pointer;transition:var(--transition);box-shadow:0 4px 15px rgba(52,152,219,0.3)}
.download-btn.complete {background:linear-gradient(135deg,#27ae60 0%,#16a085 100%);animation:pulse 2s infinite}
@keyframes pulse {0%{box-shadow:0 4px 15px rgba(39,174,96,0.3)}50%{box-shadow:0 4px 25px rgba(39,174,96,0.5)}100%{box-shadow:0 4px 15px rgba(39,174,96,0.3)}}
.clear-all-btn {background:linear-gradient(135deg,#e74c3c 0%,#c0392b 100%);color:#fff;padding:10px 20px;border:none;border-radius:var(--radius-full);font-weight:600;font-size:14px;cursor:pointer;transition:var(--transition);margin-top:15px;opacity:0.8}
.clear-all-btn:hover {opacity:1;transform:translateY(-1px);box-shadow:0 4px 12px rgba(231,76,60,0.3)}
.loading-dots {display:inline-block;letter-spacing:2px}
.loading-dots .dot {display:inline-block;animation:dotBounce 1.4s infinite ease-in-out both}
.loading-dots .dot:nth-child(1){animation-delay:-0.32s}
.loading-dots .dot:nth-child(2){animation-delay:-0.16s}
@keyframes dotBounce {0%,80%,100%{opacity:0.3;transform:scale(0.8)}40%{opacity:1;transform:scale(1.2)}}
.proposal-image-header {animation:fadeIn 0.5s ease-out}
@keyframes fadeIn {from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.animal-circle {transition:transform 0.5s cubic-bezier(0.4,0,0.2,1)!important;animation:fadeInScale 0.6s ease-out}
.animal-circle:hover {transform:scale(1.1)}
@keyframes fadeInScale {from{opacity:0;transform:scale(0.8)}to{opacity:1;transform:scale(1)}}
.project-image-container {width:200px;height:200px;border-radius:50%;overflow:hidden;border:5px solid #fff;box-shadow:0 10px 30px rgba(0,0,0,0.2);position:relative;background:#f0f0f0;transition:all 0.8s cubic-bezier(0.4,0,0.2,1);cursor:pointer}
.project-image-container:hover {transform:scale(1.5);box-shadow:0 20px 50px rgba(0,0,0,0.3);border-width:3px}
.project-canvas {width:100%;height:100%;display:block;transition:transform 3s cubic-bezier(0.4,0,0.2,1);transform-origin:center center}
@keyframes panZoom {0%{transform:scale(1) translate(0,0)}25%{transform:scale(1.3) translate(-10%,-10%)}50%{transform:scale(1.5) translate(10%,-10%)}75%{transform:scale(1.3) translate(10%,10%)}100%{transform:scale(1.2) translate(-5%,5%)}}
.project-image-container:hover .project-canvas {animation:panZoom 6s ease-in-out infinite alternate}
@media (max-width:1024px){.proposal-main-content{grid-template-columns:1fr}.metrics-list{grid-template-columns:1fr}.form-row{grid-template-columns:1fr;gap:20px}}
@media (max-width:768px){.header h1{font-size:36px}.header p{font-size:18px}.scope-section{grid-template-columns:1fr;padding:20px}.proposal-header{padding:20px;flex-direction:column;text-align:center}.proposal-emoji{font-size:50px}.proposal-header h3{font-size:22px}.proposal-main-content{padding:20px;gap:20px}.proposal-section{padding:20px}.risks-grid,.use-cases-list{grid-template-columns:1fr}.next-steps-list{flex-direction:column}.next-steps-list li{min-width:100%}.analysis-grid{grid-template-columns:1fr}.progress-indicator{bottom:10px;left:10px;right:10px;min-width:auto;max-width:none}.proposals-header{flex-direction:column;align-items:stretch}.download-section{align-items:stretch;margin-top:15px}.download-info{text-align:center;margin-bottom:10px}.download-actions{flex-direction:column}.summary-grid{grid-template-columns:1fr}.executive-summary{padding:20px}.made-with-footer{bottom:10px;right:10px;font-size:11px;padding:6px 12px}.made-with-footer::before{font-size:14px}.proposal-price{padding:20px}.price-value{font-size:24px}.price-financing{gap:6px}.financing-info,.grants-info{font-size:12px}}