@tailwind base;@tailwind components;@tailwind utilities;@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;600&family=Inter:wght@400;500;600&display=swap");:root{--font-primary:"Noto Sans KR","Inter",-apple-system,BlinkMacSystemFont,sans-serif;--font-display:"Noto Sans KR","Inter",-apple-system,BlinkMacSystemFont,sans-serif;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-md:1.125rem;--text-lg:1.25rem;--text-xl:1.375rem;--display-sm:1.5rem;--display-md:1.75rem;--display-lg:2rem;--display-xl:2.25rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.75;--primary-700:#5b21b6;--primary-600:#7c3aed;--primary-500:#8b5cf6;--primary-400:#a78bfa;--primary-300:#c4b5fd;--primary-200:#ddd6fe;--primary-100:#ede9fe;--primary-50:#f5f3ff;--accent-500:#ec4899;--accent-100:#fce7f3;--info-700:#0369a1;--info-600:#0284c7;--info-500:#0ea5e9;--info-400:#38bdf8;--info-100:#e0f2fe;--info-50:#f0f9ff;--warning-500:#f59e0b;--warning-100:#fef3c7;--error-500:#ef4444;--error-100:#fee2e2;--gray-900:#111827;--gray-800:#1f2937;--gray-700:#374151;--gray-600:#4b5563;--gray-500:#6b7280;--gray-400:#9ca3af;--gray-300:#d1d5db;--gray-200:#e5e7eb;--gray-100:#f3f4f6;--gray-50:#f9fafb;--success-500:#10b981;--success-100:#dcfce7;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--shadow-sm:0 1px 2px 0 rgb(0 0 0/0.05);--shadow-md:0 4px 6px -1px rgb(0 0 0/0.1),0 2px 4px -2px rgb(0 0 0/0.1);--shadow-lg:0 10px 15px -3px rgb(0 0 0/0.1),0 4px 6px -4px rgb(0 0 0/0.1)}*{box-sizing:border-box}:focus-visible{outline:3px solid var(--primary-500);outline-offset:3px;box-shadow:0 0 0 1px var(--primary-200)}.loading-state{color:var(--gray-600)}.empty-state-icon{display:block}body{font-family:var(--font-primary);font-size:var(--text-base);margin:0;background:linear-gradient(135deg,#f8fafc,#e2e8f0 25%,#f1f5f9 50%,#ffffff);background-size:cover;background-attachment:fixed;color:var(--gray-800);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;overflow-y:auto;min-height:100vh}.container{max-width:1080px;margin:var(--space-xl) auto;background:linear-gradient(145deg,#ffffff,#f8fafc);box-shadow:0 25px 50px -12px rgba(0,0,0,.25),0 0 0 1px rgba(255,255,255,.8),inset 0 1px 0 rgba(255,255,255,.9);border-radius:var(--radius-xl);overflow:visible;border:1px solid rgba(226,232,240,.8);position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-height:1000px}@media (max-width:1120px){.container{margin:var(--space-md);max-width:calc(100vw - 2rem)}}@media (max-width:768px){.container{margin:var(--space-sm);max-width:calc(100vw - 1rem);border-radius:var(--radius-lg)}}header{padding:var(--space-xl);background:linear-gradient(135deg,rgba(124,58,237,.85),rgba(167,139,250,.75));color:white;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(124,58,237,.15),inset 0 1px 0 rgba(255,255,255,.2);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1)}header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.1) 0,transparent 50%),radial-gradient(circle at 80% 70%,rgba(255,255,255,.08) 0,transparent 50%);opacity:.6}header h1{font-family:var(--font-display);font-size:var(--display-xl);font-weight:600;margin:0 0 var(--space-lg) 0;text-align:center;position:relative;z-index:1;letter-spacing:.5px;text-shadow:0 2px 10px rgba(0,0,0,.1);line-height:var(--leading-tight)}.mobile-weather-filter-row{display:none}.global-filter-toggle{position:absolute;top:var(--space-lg);right:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm);z-index:2}.global-filter-btn{width:40px;height:40px;background:linear-gradient(145deg,rgba(255,255,255,.2),rgba(255,255,255,.1));color:white;border:2px solid rgba(255,255,255,.3);border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 4px 15px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.3)}.global-filter-btn:hover{background:linear-gradient(145deg,rgba(255,255,255,.3),rgba(255,255,255,.2));border-color:rgba(255,255,255,.5);transform:translateY(-1px) scale(1.05);box-shadow:0 8px 25px rgba(139,92,246,.4),inset 0 1px 0 rgba(255,255,255,.4)}.global-filter-btn.active{background:linear-gradient(145deg,rgba(255,255,255,.4),rgba(255,255,255,.25));border-color:rgba(255,255,255,.7);box-shadow:0 6px 20px rgba(139,92,246,.5),inset 0 1px 0 rgba(255,255,255,.5),inset 0 -1px 0 rgba(0,0,0,.1)}.preference-analysis-btn{width:40px;height:40px;background:linear-gradient(145deg,rgba(255,255,255,.2),rgba(255,255,255,.1));color:white;border:2px solid rgba(255,255,255,.3);border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 4px 15px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.3)}.preference-analysis-btn:hover{background:linear-gradient(145deg,rgba(255,255,255,.3),rgba(255,255,255,.2));border-color:rgba(255,255,255,.5);transform:translateY(-1px) scale(1.05);box-shadow:0 8px 25px rgba(139,92,246,.4),inset 0 1px 0 rgba(255,255,255,.4)}.header-guide{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:var(--space-lg);gap:var(--space-lg);margin-top:var(--space-lg);position:relative;z-index:1;align-items:start}@media (max-width:768px){.header-guide{grid-template-columns:1fr;gap:var(--space-md)}}.guide-button{background:linear-gradient(145deg,rgba(255,255,255,.1),rgba(255,255,255,.05));padding:var(--space-md);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.15);cursor:pointer;transition:all .2s ease;text-align:left;width:100%;height:100%;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px rgba(0,0,0,.08),inset 0 1px 0 rgba(255,255,255,.15);min-height:48px}@media (max-width:768px){.guide-button{min-height:56px;padding:var(--space-lg);font-size:var(--text-md)}}.guide-button:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 12px 30px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.25);transition:all .3s cubic-bezier(.4,0,.2,1)}.guide-button.active,.guide-button:hover{background:linear-gradient(145deg,rgba(255,255,255,.2),rgba(255,255,255,.15));border-color:rgba(255,255,255,.3)}.guide-button.active{box-shadow:0 6px 15px rgba(0,0,0,.12),inset 0 1px 0 rgba(255,255,255,.25),inset 0 -1px 0 rgba(0,0,0,.05)}.guide-button h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;margin:0 0 var(--space-sm) 0;color:rgba(255,255,255,.95);line-height:var(--leading-tight)}.guide-button p{font-family:var(--font-primary);font-size:var(--text-sm);line-height:var(--leading-normal);margin:0 0 var(--space-xs) 0;color:rgba(255,255,255,.88)}.guide-button p:nth-last-child(2){margin-bottom:var(--space-sm)}.guide-button .note{font-size:.8rem;color:rgba(255,255,255,.75);font-style:italic}.guide-button .layering-info{color:rgba(255,255,255,.9);font-weight:500}.guide-button-indicator{position:absolute;bottom:var(--space-sm);right:var(--space-lg);font-size:var(--text-sm);font-weight:500;color:rgba(255,255,255,.85);background:rgba(255,255,255,.08);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.card-slide-in{animation:cardSlideIn .5s ease-out;position:relative;z-index:1}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.search-card{background:linear-gradient(145deg,#ffffff,#f8fafc);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 8px 20px -5px rgba(0,0,0,.07),inset 0 1px 0 rgba(255,255,255,.7);margin-bottom:var(--space-lg);transition:box-shadow .2s ease,transform .2s ease;position:relative;overflow:visible;display:flex;flex-direction:column;width:100%}.search-card:hover{box-shadow:0 20px 40px -15px rgba(0,0,0,.12),inset 0 1px 0 rgba(255,255,255,.9);transform:translateY(-3px);border-color:rgba(139,92,246,.2)}.search-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;color:var(--gray-800);margin-bottom:var(--space-md);text-align:left;line-height:var(--leading-tight)}.search-input-container{position:relative;margin-bottom:var(--space-lg);z-index:9998;width:100%}#searchInput{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--text-base);font-family:var(--font-primary);border:2px solid var(--gray-300);border-radius:var(--radius-lg);box-sizing:border-box;background:white;transition:all .2s ease;line-height:var(--leading-normal);min-height:48px}#searchInput:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px rgba(139,92,246,.1),0 2px 10px rgba(139,92,246,.15);outline:none;position:relative;z-index:10000;transform:translateY(-1px)}#searchInput::placeholder{color:var(--gray-500)}.floating-search-results{position:absolute;top:100%;left:0;right:0;background:white;border:1px solid var(--gray-300);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:0 8px 32px rgba(0,0,0,.15);max-height:65vh;overflow-y:auto;z-index:9999;display:none;width:100%;transform:translateZ(0)}.floating-search-results.show{display:block}.floating-search-results .results-header{padding:var(--space-md) var(--space-lg);background:var(--gray-50);border-bottom:1px solid var(--gray-200);font-size:var(--text-sm);font-weight:500;color:var(--gray-600);position:-webkit-sticky;position:sticky;top:0;z-index:1001}.floating-search-results .results-list{list-style:none;padding:0;margin:0}.floating-search-results .results-list li{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--gray-100);cursor:pointer;transition:all .15s ease;font-size:var(--text-sm);font-family:var(--font-primary);color:var(--gray-700)}.floating-search-results .results-list li:last-child{border-bottom:none}.floating-search-results .results-list li:hover{background:var(--primary-50);color:var(--primary-600);transform:translateX(4px);border-left:3px solid var(--primary-400);transition:all .2s ease}.floating-search-results .results-list li.selected{background:var(--primary-500);color:white;transform:translateX(4px);border-left:3px solid var(--primary-300);box-shadow:inset 0 1px 0 rgba(255,255,255,.2)}.floating-search-results .results-list li.no-results{text-align:center;color:var(--gray-500);font-style:italic;cursor:default;padding:var(--space-xl)}.floating-search-results .results-list li.no-results:hover{background:transparent;color:var(--gray-500)}.filter-toggle-section{margin-top:var(--space-md);text-align:center;position:relative;z-index:1}.filter-toggle-btn{padding:var(--space-sm) var(--space-lg);background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-300);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-primary);font-weight:500;transition:all .2s ease}.filter-toggle-btn:hover{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700);transform:translateY(-1px);box-shadow:0 4px 12px rgba(139,92,246,.15)}.filters-section{margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--gray-200);animation:filterSlideDown .3s ease-out}@keyframes filterSlideDown{0%{opacity:0;max-height:0;overflow:hidden}to{opacity:1;max-height:500px;overflow:visible}}.filter-group{margin-bottom:var(--space-lg);display:grid;grid-template-columns:100px 1fr 1fr 1fr;grid-gap:var(--space-md);gap:var(--space-md);align-items:center}@media (max-width:768px){.filter-group{grid-template-columns:1fr;gap:var(--space-sm);text-align:left}.filter-group h3{margin-bottom:var(--space-sm)}}.filter-group:last-child{margin-bottom:0}.filter-group h3{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;margin:0;color:var(--gray-800);line-height:var(--leading-tight)}.filters-section select{padding:var(--space-md);border:1px solid var(--gray-300);border-radius:var(--radius-md);background:white;font-size:var(--text-sm);font-family:var(--font-primary);color:var(--gray-700);transition:all .2s ease;cursor:pointer;min-width:0;max-width:100%;min-height:44px}@media (max-width:768px){.filters-section select{min-height:48px;font-size:var(--text-base);padding:var(--space-lg)}}.filters-section select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px rgba(139,92,246,.1);outline:none;transform:translateY(-1px)}.filters-section select:hover{border-color:var(--primary-300);transform:translateY(-1px);box-shadow:0 2px 8px rgba(139,92,246,.1)}#resetFiltersButton{padding:var(--space-md) var(--space-lg);background:white;color:var(--gray-700);border:1px solid var(--gray-300);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-primary);font-weight:500;transition:all .2s ease;margin-top:var(--space-md);align-self:flex-start;box-shadow:var(--shadow-sm);min-height:44px}@media (max-width:768px){#resetFiltersButton{min-height:48px;font-size:var(--text-base);padding:var(--space-lg);width:100%}}#resetFiltersButton:hover{background:var(--gray-50);border-color:var(--gray-400);transform:translateY(-1px);box-shadow:var(--shadow-md)}main{padding:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-lg);align-items:center}.search-section{width:100%;margin-bottom:0;position:relative;z-index:10;overflow:visible}.content-section{width:100%;display:grid;grid-template-columns:1fr;grid-gap:var(--space-xl);gap:var(--space-xl);align-items:start}.details-column{display:flex;flex-direction:column;gap:var(--space-xl)}.layering-section,.recommendation-results-section,.recommendation-section{width:100%}.layering-recommendations-section,.recommendation-card,.recommendation-results-card,.search-results-section,.selected-perfume-details-section,.similar-results-card{margin-bottom:var(--space-lg);background:linear-gradient(145deg,#ffffff,#f8fafc);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 8px 20px -5px rgba(0,0,0,.07),inset 0 1px 0 rgba(255,255,255,.7);transition:box-shadow .2s ease,transform .2s ease;width:100%}.layering-recommendations-section:hover,.recommendation-card:hover,.recommendation-results-card:hover,.search-results-section:hover,.selected-perfume-details-section:hover,.similar-results-card:hover{box-shadow:0 15px 30px -10px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.8);transform:translateY(-2px)}.layering-recommendations-section:last-child,.search-results-section:last-child,.selected-perfume-details-section:last-child{margin-bottom:0}.layering-recommendations-section h3,.recommendation-card h2,.recommendation-results-card h2,.recommendation-tab h3,.search-card h2,.search-results-section h2,.selected-perfume-details-section h2,.similar-card h2,.similar-perfume-column h3,.similar-results-card h2,.user-preference-analysis h3{font-family:var(--font-display);font-size:var(--display-base);font-weight:600;margin-top:0;color:var(--gray-800);display:flex;align-items:center;padding-bottom:var(--space-md);border-bottom:1px solid var(--gray-200);margin-bottom:var(--space-lg)}.recommendation-card h2,.recommendation-results-card h2,.search-card h2,.search-results-section h2,.selected-perfume-details-section h2{justify-content:space-between}.recommendation-card h2{border-bottom:none}.similar-card h2,.similar-results-card h2{justify-content:center;text-align:center}.search-card h2{justify-content:flex-start;border-bottom:none}.layering-recommendations-section h3,.recommendation-tab h3,.similar-perfume-column h3,.user-preference-analysis h3{font-family:var(--font-display);font-size:var(--display-sm);font-weight:600;margin-top:0;color:var(--gray-700);display:flex;align-items:center;padding-bottom:var(--space-sm);border-bottom:1px solid var(--gray-200);margin-bottom:var(--space-md)}.user-preference-analysis h3{color:var(--gray-700)}.layering-recommendations-section h3,.recommendation-tab h3{justify-content:flex-start}.similar-perfume-column h3{justify-content:center}#resultsCount{font-size:var(--text-sm);font-weight:500;font-family:var(--font-primary);color:var(--gray-600);background:var(--gray-100);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}#resultsList{list-style-type:none;padding:0;margin:0;max-height:400px;overflow-y:auto}#resultsList li{padding:var(--space-md);border-bottom:1px solid var(--gray-100);cursor:pointer;transition:all .2s ease;font-size:var(--text-sm);font-family:var(--font-primary);border-radius:var(--radius-sm);margin-bottom:var(--space-xs);position:relative}#resultsList li:last-child{border-bottom:none}#resultsList li:hover{background:var(--primary-50);color:var(--primary-600);transform:translateX(4px)}#resultsList li.selected{background:var(--primary-500);color:white;font-weight:500;box-shadow:var(--shadow-md)}#resultsList li strong{background:rgba(251,191,36,.3);color:var(--gray-800);padding:1px 4px;border-radius:var(--radius-sm);font-weight:600}#perfumeDetailsContent h3{margin:0 0 var(--space-lg) 0;color:var(--primary-600);font-family:var(--font-display);font-size:var(--display-base);font-weight:600}#perfumeDetailsContent h4{font-size:var(--text-lg);font-family:var(--font-display);font-weight:600;color:var(--gray-700);margin:var(--space-lg) 0 var(--space-md) 0;border-bottom:1px solid var(--gray-200);padding-bottom:var(--space-sm)}#perfumeDetailsContent p{margin-bottom:var(--space-md);color:var(--gray-600);font-size:var(--text-base);font-family:var(--font-primary)}#perfumeDetailsContent ul{list-style-type:none;padding-left:0;margin-bottom:var(--space-lg)}#perfumeDetailsContent li,.layering-perfume-column li,.similar-perfume-column li{margin-bottom:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--gray-50);border-radius:var(--radius-sm);border-left:2px solid var(--primary-400);position:relative;overflow:hidden;min-height:28px;display:flex;align-items:center;font-weight:500;width:100%;box-sizing:border-box}.graph-bar{position:absolute!important;top:0!important;left:0!important;height:100%!important;max-width:100%!important;width:auto!important;background:linear-gradient(90deg,rgba(139,92,246,.15),rgba(139,92,246,.08) 70%,transparent)!important;border-radius:var(--radius-sm);z-index:0;overflow:hidden!important}.graph-bar-content{position:relative;z-index:1;width:100%;display:flex;justify-content:space-between;align-items:center}.percentage-value{font-weight:600;color:var(--primary-600);font-size:var(--text-sm);background:rgba(255,255,255,.8);padding:2px 6px;border-radius:var(--radius-sm)}.layering-quick-links{background:linear-gradient(135deg,#f0f9ff,#e0f2fe 25%,#f8fafc 75%,#ffffff);padding:var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);border:1px solid rgba(139,92,246,.3);box-shadow:0 8px 20px -5px rgba(139,92,246,.1),inset 0 1px 0 rgba(255,255,255,.8)}.layering-quick-links h4{margin:0 0 var(--space-md) 0;font-family:var(--font-display);font-size:var(--text-lg);color:var(--gray-700);font-weight:600}.layering-links-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:var(--space-md)}.layering-links-list li{display:flex;align-items:center;gap:var(--space-sm)}.layering-link{color:var(--primary-600);text-decoration:none;font-weight:500;font-family:var(--font-primary);font-size:var(--text-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:all .2s ease;border:1px solid var(--primary-400);background:white}.layering-link:hover{background:var(--primary-600);color:white;text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow-md)}.layering-score{font-size:var(--text-sm);font-family:var(--font-primary);color:var(--success-500);font-weight:700;background:var(--success-100);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);white-space:nowrap}.layering-cards-section{margin-top:var(--space-xl)}.layering-cards-section h4{margin:0 0 var(--space-lg) 0;font-family:var(--font-display);font-size:var(--text-lg);color:var(--gray-700);font-weight:600;padding-bottom:var(--space-md);border-bottom:1px solid var(--gray-200)}.layering-item-box{background:linear-gradient(145deg,#ffffff,#f8fafc);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:0 8px 20px -5px rgba(0,0,0,.07),inset 0 1px 0 rgba(255,255,255,.7);scroll-margin-top:var(--space-xl);transition:box-shadow .2s ease,transform .2s ease}.layering-item-box:hover{box-shadow:0 15px 30px -10px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.8);transform:translateY(-2px)}.layering-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:2px solid var(--primary-400)}.layering-card-title{margin:0;font-family:var(--font-display);font-size:var(--display-sm);font-weight:600;color:var(--primary-600);line-height:1.3}.layering-item-box .layering-rationale{margin-top:var(--space-lg);margin-bottom:0}.layering-item-box .score{font-weight:600;color:var(--gray-700);margin-bottom:var(--space-md);font-size:var(--text-base);font-family:var(--font-primary)}.layering-item-box .score .label{font-weight:600;color:var(--gray-800);margin-right:var(--space-sm)}.layering-item-box .score .score-value{font-weight:700;color:var(--success-500);font-size:1.1em}.layering-item-box .reasoning{line-height:1.6;margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--gray-50);border-radius:var(--radius-md);border-left:3px solid var(--primary-400)}.layering-item-box .back-to-list-btn,.layering-item-box .reasoning{font-size:var(--text-sm);font-family:var(--font-primary);color:var(--gray-600)}.layering-item-box .back-to-list-btn{background:white;border:1px solid var(--gray-300);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;font-weight:500;white-space:nowrap;display:block;width:-moz-fit-content;width:fit-content;margin:var(--space-md) auto 0;box-shadow:var(--shadow-sm)}.layering-item-box .back-to-list-btn:hover{background:var(--primary-600);border-color:var(--primary-600);color:white;transform:translateY(-1px);box-shadow:var(--shadow-md)}.layering-columns{display:flex;justify-content:space-between;gap:var(--space-xl);margin-bottom:var(--space-lg);padding-bottom:var(--space-lg)}.layering-columns.show-details{border-bottom:1px dashed var(--gray-300)}.layering-perfume-column{flex:1 1;min-width:0;background:linear-gradient(145deg,#ffffff,#f8fafc 50%,#f1f5f9);border:1px solid rgba(139,92,246,.2);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:0 8px 25px -8px rgba(139,92,246,.15),0 0 0 1px rgba(255,255,255,.9),inset 0 1px 0 rgba(255,255,255,.8);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.layering-perfume-column:hover{box-shadow:0 15px 40px -10px rgba(139,92,246,.25),0 0 0 1px rgba(255,255,255,.95),inset 0 1px 0 rgba(255,255,255,.9);transform:translateY(-2px);border-color:rgba(139,92,246,.3)}.layering-perfume-column:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 20%,rgba(139,92,246,.05) 0,transparent 50%);pointer-events:none;z-index:0}.layering-perfume-column>*{position:relative;z-index:1}.layering-perfume-column .perfume-title-in-layering{font-size:var(--text-lg);font-family:var(--font-display);color:var(--primary-600);margin-bottom:var(--space-md);font-weight:600;line-height:1.4}.layering-perfume-column h4{font-size:var(--text-base);font-family:var(--font-primary);margin-top:var(--space-md);color:var(--gray-700);font-weight:600}.layering-perfume-column ul{margin-bottom:var(--space-md);padding-left:0;list-style:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.loading-state{display:flex;justify-content:center;align-items:center}.empty-state,.loading-state{padding:var(--space-xl);color:var(--gray-500);font-family:var(--font-primary);font-size:var(--text-base)}.empty-state{text-align:center}.empty-state-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.5}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:900px){.container{margin:var(--space-md);border-radius:var(--radius-lg);max-width:none}header{padding:var(--space-lg)}header h1{font-size:var(--display-base)}.header-guide{grid-template-columns:1fr;gap:var(--space-md);margin-top:var(--space-sm);order:3}header{display:flex;flex-direction:column;align-items:center}header h1{margin:0;order:1;font-size:var(--display-md)}.global-filter-toggle:not(.mobile-weather-filter-row .global-filter-toggle),.weather-info-banner:not(.mobile-weather-filter-row .weather-info-banner){display:none!important}.mobile-weather-filter-row{display:flex!important;justify-content:center;align-items:center;gap:var(--space-md);order:2;margin:var(--space-md) 0 var(--space-sm) 0}.mobile-weather-filter-row .weather-info-banner{position:static!important;margin:0!important;text-align:center;width:auto}.mobile-weather-filter-row .global-filter-toggle{position:static!important;justify-content:center;margin:0}.global-filter-btn,.preference-analysis-btn{width:36px;height:36px;font-size:14px}.guide-button{padding:var(--space-md)}.guide-button h3{font-size:var(--text-base)}.guide-button p{font-size:.75rem}.guide-button-indicator{position:static;margin-top:var(--space-md);text-align:center;background:rgba(255,255,255,.15)}main{padding:var(--space-lg)}.content-section,main{gap:var(--space-lg)}#searchInput,.filters-section select{font-size:var(--text-sm);padding:var(--space-md)}.layering-recommendations-section,.search-results-section,.selected-perfume-details-section{padding:var(--space-lg)}.floating-search-results{max-height:50vh;left:0;right:0;box-shadow:0 8px 32px rgba(0,0,0,.2);border-radius:0 0 var(--radius-md) var(--radius-md);margin:0;width:100%;transform:translateZ(0)}.search-section{margin-bottom:calc(var(--space-xl) + 100px)}#resultsList li{padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);margin-bottom:var(--space-xs)}.filter-group{grid-template-columns:1fr;gap:var(--space-sm)}.filter-group h3{margin-bottom:var(--space-sm)}.filters-section select{width:100%;min-width:auto;max-width:none}#resetFiltersButton{width:100%}.filter-toggle-btn{font-size:.8rem;padding:var(--space-sm) var(--space-md)}.layering-columns{flex-direction:column;gap:var(--space-lg)}.layering-perfume-column{padding:var(--space-lg);margin-bottom:var(--space-lg)}.layering-columns.show-details .layering-perfume-column{border-bottom:1px dashed rgba(139,92,246,.2)}.layering-columns.show-details .layering-perfume-column:last-child{border-bottom:none;margin-bottom:0}.layering-links-list{flex-direction:column;gap:var(--space-sm)}.layering-card-title{font-size:var(--text-lg);line-height:1.3}.layering-perfume-column .perfume-title-in-layering{font-size:var(--text-base);line-height:1.3}}.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}.focus\:not-sr-only:focus{position:static;width:auto;height:auto;padding:inherit;margin:inherit;overflow:visible;clip:auto;white-space:normal}:focus{outline:2px solid var(--primary-500);outline-offset:2px}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}@media (prefers-contrast:high){:root{--primary-600:#5b21b6;--primary-500:#7c3aed;--gray-800:#000000;--gray-700:#1a1a1a;--gray-600:#333333}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);font-family:var(--font-primary);font-size:var(--text-sm);font-weight:500;line-height:1;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease,border-color .15s ease}.btn:active{transform:translateY(0)}.btn-outline{background:white;color:var(--gray-700);border-color:var(--gray-300);box-shadow:var(--shadow-sm)}.btn-outline:hover{background:var(--gray-50);border-color:var(--gray-400);box-shadow:var(--shadow-md)}.btn-primary{background:var(--primary-600);color:#fff;border-color:var(--primary-600);box-shadow:0 6px 16px rgba(124,58,237,.25)}.btn-primary:hover{background:var(--primary-500);border-color:var(--primary-500);box-shadow:0 10px 22px rgba(124,58,237,.35)}.search-card-reset-section{margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--gray-200);display:flex;align-items:center;gap:var(--space-md)}@media (min-width:901px){.content-section,.header-guide,.layering-section,.recommendation-results-section,.recommendation-section,.search-section,.similar-results-section,.similar-section{max-width:960px;margin-left:auto;margin-right:auto;width:100%}.recommendation-card,.search-card,.similar-card,.weather-info-banner{max-width:960px;margin-left:auto;margin-right:auto}}.recommendation-tab{margin-bottom:var(--space-xl);padding:var(--space-lg);border:1px solid rgba(226,232,240,.6);border-radius:var(--radius-md);background:linear-gradient(145deg,#f8fafc,#f1f5f9);transition:all .2s ease;box-shadow:0 4px 12px -2px rgba(0,0,0,.05),inset 0 1px 0 rgba(255,255,255,.7)}.recommendation-tab:hover{background:linear-gradient(145deg,#ffffff,#f8fafc);box-shadow:0 8px 20px -5px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.8)}.recommendation-tab h3{font-family:var(--font-display);font-size:var(--display-sm);font-weight:600;margin:0 0 var(--space-lg) 0;color:var(--gray-700);padding-bottom:var(--space-sm);border-bottom:1px solid var(--gray-300)}.recommendation-tab:last-child{margin-bottom:0}.recommendation-form{gap:var(--space-md)}.form-row,.recommendation-form{display:flex;flex-direction:column}.form-row{gap:var(--space-xs)}.form-row label{font-size:var(--text-sm);font-weight:500;color:var(--gray-700);text-align:left;margin-bottom:var(--space-xs)}.form-row input,.form-row select{padding:var(--space-md);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-primary);background:white;transition:all .2s ease}.form-row input:focus,.form-row select:focus{border-color:var(--gray-500);box-shadow:0 0 0 2px var(--gray-100);outline:none}.emotion-selector{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin:var(--space-md) 0;padding:var(--space-md);border:1px solid var(--gray-200);border-radius:var(--radius-md);background:white;max-height:200px;overflow-y:auto}.emotion-tag{padding:var(--space-xs) var(--space-md);background:var(--gray-100);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-primary);color:var(--gray-700);cursor:pointer;transition:all .2s ease;white-space:nowrap}.emotion-tag:hover{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-600)}.emotion-tag.selected{border-color:var(--primary-600)}.emotion-tag.selected,.recommend-btn{background:var(--primary-500);color:white;font-weight:500}.recommend-btn{padding:var(--space-md) var(--space-lg);border:1px solid var(--primary-500);border-radius:var(--radius-md);font-size:var(--text-base);font-family:var(--font-primary);cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px rgba(139,92,246,.2),inset 0 1px 0 rgba(255,255,255,.1);align-self:flex-start}.recommend-btn:hover:not(:disabled){background:linear-gradient(145deg,#7C3AED,#6d28d9);transform:translateY(-1px);box-shadow:0 8px 25px rgba(139,92,246,.4),inset 0 1px 0 rgba(255,255,255,.3)}.recommend-btn:disabled{background:var(--gray-400);color:var(--gray-600);cursor:not-allowed;opacity:.6;box-shadow:none}.result-tab{margin-bottom:var(--space-xl);padding:var(--space-lg);border:1px solid var(--gray-200);border-radius:var(--radius-md);background:var(--gray-50)}.result-tab h3{font-family:var(--font-display);font-size:var(--display-sm);font-weight:600;margin:0 0 var(--space-lg) 0;color:var(--gray-700);padding-bottom:var(--space-sm);border-bottom:1px solid var(--gray-300)}.recommendation-list{display:flex;flex-direction:column;gap:var(--space-md)}.recommendation-item{padding:var(--space-lg);background:white;border:1px solid var(--gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all .2s ease}.recommendation-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.rec-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.rec-header h4{font-family:var(--font-primary);font-size:var(--text-lg);font-weight:600;margin:0;color:var(--gray-800)}.similarity-score{color:var(--primary-600);background:var(--primary-50);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.select-perfume-btn,.similarity-score{font-size:var(--text-sm);font-weight:500}.select-perfume-btn{padding:var(--space-sm) var(--space-md);background:white;color:var(--gray-700);border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-family:var(--font-primary);cursor:pointer;transition:all .2s ease}.select-perfume-btn:hover{background:var(--gray-50);border-color:var(--gray-400);transform:translateY(-1px)}@media (max-width:900px){.recommendation-card,.recommendation-results-card{padding:var(--space-lg)}.form-row label{text-align:left;font-weight:600}.emotion-selector{max-height:150px}.emotion-tag{font-size:.75rem;padding:var(--space-xs) var(--space-sm)}.rec-header{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.recommendation-item{padding:var(--space-md)}}.emotion-tag-cloud{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin:0 0 var(--space-md) 0;padding:var(--space-lg);border:1px solid var(--gray-200);border-radius:var(--radius-md);background:linear-gradient(135deg,var(--gray-50) 0,#fefefe 100%);max-height:300px;overflow-y:auto;justify-content:center;align-items:flex-start;line-height:1.2;position:relative}.emotion-cloud-tag{padding:calc(var(--space-xs) + 2px) calc(var(--space-sm) + 4px);background:var(--gray-100);border:1px solid var(--gray-300);border-radius:var(--radius-lg);font-family:var(--font-primary);color:var(--gray-700);cursor:pointer;transition:all .3s ease;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;display:inline-block;position:relative;font-weight:400;text-align:center;min-width:-moz-fit-content;min-width:fit-content}.emotion-cloud-tag:hover{background:var(--primary-100);border-color:var(--primary-300);color:var(--primary-700);box-shadow:var(--shadow-sm)}.emotion-cloud-tag.selected{background:linear-gradient(135deg,var(--primary-500) 0,var(--primary-600) 100%);border-color:var(--primary-700);color:white;font-weight:500;box-shadow:var(--shadow-md);z-index:2}.selected-emotions-summary{margin:var(--space-md) 0;padding:var(--space-md);background:var(--primary-50);border-radius:var(--radius-md);border:1px solid var(--primary-200);border-left:4px solid var(--primary-500)}.selected-emotions-summary p{margin:0;font-size:var(--text-sm);color:var(--primary-700);font-weight:500}.recommendation-detailed-list{display:flex;flex-direction:column;gap:var(--space-xl)}.recommendation-detailed-item{background:white;border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden!important;width:100%;max-width:100%;box-sizing:border-box}.recommendation-detailed-item:hover{box-shadow:var(--shadow-lg);border-color:var(--primary-300)}.recommendation-detailed-item .rec-header{padding:var(--space-lg);background:linear-gradient(135deg,var(--gray-50) 0,#fefefe 100%);border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;gap:var(--space-md)}.recommendation-detailed-item .rec-header h4{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;margin:0;color:var(--gray-800);flex:1 1}.recommendation-detailed-item .similarity-score{font-size:var(--text-sm);font-weight:600;color:var(--primary-600);background:var(--primary-100);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-lg);border:1px solid var(--primary-200)}.recommendation-detailed-item .select-perfume-btn{padding:var(--space-sm) var(--space-lg);background:var(--primary-500);color:white;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-primary);font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.recommendation-detailed-item .select-perfume-btn:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-md)}.recommendation-detailed-item .rec-details{padding:0;overflow:hidden;width:100%;box-sizing:border-box}.recommendation-detailed-item .rec-details h3{color:var(--primary-600);font-size:var(--display-sm);margin-bottom:var(--space-md)}.recommendation-detailed-item .rec-details h4{color:var(--gray-700);font-size:var(--text-base);margin:var(--space-lg) 0 var(--space-sm) 0;font-weight:600}@media (max-width:900px){.emotion-tag-cloud{padding:var(--space-md);max-height:250px;justify-content:flex-start}.emotion-cloud-tag{font-size:.75rem;padding:var(--space-xs) var(--space-sm)}.recommendation-detailed-item .rec-header{flex-direction:column;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md)}.recommendation-detailed-item .rec-details{padding:0}.selected-emotions-summary{margin:var(--space-sm) 0;padding:var(--space-sm)}}.recommendation-reset-section{margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--gray-200);display:flex;align-items:center;gap:var(--space-md)}.recommendation-reset-btn{padding:var(--space-sm) var(--space-md);background:white;color:var(--gray-700);border:1px solid var(--gray-300);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-primary);font-weight:500;box-shadow:var(--shadow-sm);white-space:nowrap}.recommendation-reset-btn:hover{background:var(--gray-50);border-color:var(--gray-400);color:var(--gray-700);box-shadow:var(--shadow-md)}.reset-description{font-size:var(--text-sm);color:var(--gray-600);font-family:var(--font-primary)}@media (max-width:900px){.recommendation-reset-section{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.recommendation-reset-btn{width:100%;text-align:center}}.similar-card{background:linear-gradient(145deg,#ffffff,#f8fafc);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 8px 20px -5px rgba(0,0,0,.07),inset 0 1px 0 rgba(255,255,255,.7);margin-bottom:var(--space-lg);transition:box-shadow .2s ease,transform .2s ease;width:100%}.similar-card:hover{box-shadow:0 15px 30px -10px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.8);transform:translateY(-2px)}.similar-card h2{font-family:var(--font-display);font-size:var(--display-base);font-weight:600;margin:0 0 var(--space-lg) 0;color:var(--gray-800);justify-content:flex-start;padding-bottom:var(--space-md);border-bottom:none!important}.similar-reset-section{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--gray-200)}.similar-reset-btn{padding:var(--space-sm) var(--space-md);background:white;color:var(--gray-700);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-primary);font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm);white-space:nowrap}.similar-reset-btn:hover{background:var(--gray-50);border-color:var(--gray-400);transform:translateY(-1px);box-shadow:var(--shadow-md)}.similar-search-container{position:relative;margin-bottom:var(--space-lg);z-index:9998}.similar-search-container input{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--text-base);font-family:var(--font-primary);border:1px solid var(--gray-300);border-radius:var(--radius-lg);box-sizing:border-box;background:white;transition:all .3s ease}.similar-search-container input:focus{border-color:var(--gray-500);box-shadow:0 0 0 2px var(--gray-100);outline:none;position:relative;z-index:10000}.similar-search-container input::placeholder{color:var(--gray-500)}.finding-similar-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-xl);background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--gray-200)}.finding-similar-loading p{font-size:var(--text-base);color:var(--gray-600);margin:0;text-align:center}.similar-results-card{background:white;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-md);margin-bottom:var(--space-lg)}.similar-results-card h2{font-family:var(--font-display);font-size:var(--display-base);font-weight:600;margin:0 0 var(--space-xl) 0;color:var(--gray-800);text-align:center;padding-bottom:var(--space-md);border-bottom:2px solid var(--primary-100)}.similar-comparison-improved{display:grid;grid-template-columns:1fr auto 1fr;grid-gap:var(--space-xl);gap:var(--space-xl);align-items:stretch;margin-bottom:var(--space-xl)}.perfume-card{background:white;border:1px solid var(--gray-200);border-radius:var(--radius-md);overflow:hidden;transition:all .2s ease;position:relative;box-shadow:var(--shadow-sm)}.perfume-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--gray-300)}.perfume-card.base-perfume,.perfume-card.similar-perfume{border:1px solid var(--gray-200);box-shadow:var(--shadow-sm)}.perfume-card-header{padding:var(--space-md) var(--space-lg) 0}.perfume-badge{display:inline-block;font-size:var(--text-sm);font-weight:600;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-lg);text-transform:uppercase;letter-spacing:.5px}.perfume-badge.base{background:linear-gradient(135deg,var(--info-100) 0,var(--info-50) 100%);color:var(--info-700);border:2px solid var(--info-600);font-weight:600}.perfume-badge.similar{background:linear-gradient(135deg,var(--primary-100) 0,var(--primary-50) 100%);color:var(--primary-700);border:2px solid var(--primary-600);font-weight:600}.perfume-card-content{padding:var(--space-md) var(--space-lg) var(--space-lg)}.perfume-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--gray-800);margin:0 0 var(--space-md) 0;line-height:var(--leading-tight)}.perfume-details{background:white;border-radius:var(--radius-md);padding:var(--space-md);border:none}.perfume-details-content{display:flex;flex-direction:column;gap:var(--space-lg)}.details-section{margin:0}.details-title{font-size:var(--text-xs);font-weight:500;color:var(--gray-700);margin:0 0 var(--space-md) 0;font-family:var(--font-display)}.details-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-md)}.details-item{margin:0}.item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs)}.item-name{font-weight:500;color:var(--gray-700)}.item-name,.item-value{font-size:var(--text-sm);font-family:var(--font-primary)}.item-value{font-weight:600}.accord-value{color:var(--primary-600)}.note-value{color:var(--info-600)}.progress-bar{width:100%;height:8px;background:var(--gray-200);overflow:hidden}.progress-bar,.progress-fill{border-radius:var(--radius-sm);position:relative}.progress-fill{height:100%;transition:width .3s ease}.accord-fill{background:linear-gradient(90deg,var(--primary-500) 0,var(--primary-400) 100%)}.note-fill{background:linear-gradient(90deg,var(--info-500) 0,var(--info-400) 100%)}@media (max-width:768px){.perfume-details-content{gap:var(--space-md)}.item-name,.item-value{font-size:var(--text-xs)}}.similarity-indicator{flex-direction:column;gap:var(--space-md);padding:var(--space-lg) var(--space-md);position:relative}.similarity-arrow,.similarity-indicator{display:flex;align-items:center;justify-content:center}.similarity-arrow{width:60px;height:60px;background:linear-gradient(135deg,var(--primary-500) 0,var(--primary-400) 100%);border-radius:50%;box-shadow:0 8px 25px rgba(139,92,246,.3),inset 0 1px 0 rgba(255,255,255,.3);animation:pulse 2s infinite}.similarity-icon{font-size:1.5rem;color:white;font-weight:700}.similarity-score{text-align:center;background:white;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);border:2px solid var(--primary-200);box-shadow:var(--shadow-sm)}.similarity-label{display:block;font-size:var(--text-xs);font-weight:500;color:var(--gray-600);margin-bottom:var(--space-xs)}.similarity-percentage{display:block;font-size:var(--text-lg);font-weight:700;color:var(--primary-600)}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 8px 25px rgba(139,92,246,.3),inset 0 1px 0 rgba(255,255,255,.3)}50%{transform:scale(1.05);box-shadow:0 12px 35px rgba(139,92,246,.4),inset 0 1px 0 rgba(255,255,255,.4)}}.similar-perfume-column h3{font-family:var(--font-display);font-size:var(--text-lg);color:var(--gray-700);padding-bottom:var(--space-sm);border-bottom:1px solid var(--gray-300)}.similar-perfume-column h3,.similar-perfume-column h4{font-weight:600;margin:0 0 var(--space-md) 0;text-align:center}.similar-perfume-column h4{font-family:var(--font-primary);font-size:var(--text-base);color:var(--gray-800)}.similar-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md)}.similar-arrow span{font-size:2rem;color:var(--primary-500)}.similar-arrow p{font-size:var(--text-sm);color:var(--gray-600);margin:0;text-align:center;font-weight:500}.similar-actions-improved{margin-top:var(--space-xl);padding:var(--space-xl);background:linear-gradient(135deg,var(--gray-50) 0,#ffffff 100%);border-radius:var(--radius-lg);border:1px solid var(--gray-200);text-align:center}.action-section{max-width:600px;margin:0 auto}.action-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--gray-800);margin:0 0 var(--space-sm) 0;line-height:var(--leading-tight)}.action-description{font-family:var(--font-primary);font-size:var(--text-base);color:var(--gray-600);margin:0 0 var(--space-lg) 0;line-height:var(--leading-normal)}.action-buttons{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-lg);gap:var(--space-lg);max-width:500px;margin:0 auto}.action-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl);border-radius:var(--radius-lg);font-family:var(--font-primary);font-size:var(--text-base);font-weight:600;border:2px solid;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:56px;position:relative;overflow:hidden}.action-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.action-btn:hover:before{left:100%}.action-btn.primary{background:white;border-color:var(--info-500);color:var(--info-600);box-shadow:0 4px 15px rgba(14,165,233,.1)}.action-btn.primary:hover{background:var(--info-50);border-color:var(--info-600);color:var(--info-700);transform:translateY(-2px);box-shadow:0 8px 25px rgba(14,165,233,.2)}.action-btn.secondary{background:white;border-color:var(--primary-500);color:var(--primary-600);box-shadow:0 4px 15px rgba(139,92,246,.1)}.action-btn.secondary:hover{background:var(--primary-50);border-color:var(--primary-600);color:var(--primary-700);transform:translateY(-2px);box-shadow:0 8px 25px rgba(139,92,246,.2)}.btn-icon{font-size:var(--text-lg)}.btn-text{font-weight:600}@media (max-width:900px){.similar-card,.similar-results-card{padding:var(--space-lg)}.similar-reset-section{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.similar-reset-btn{width:100%;text-align:center}.similar-comparison-improved{grid-template-columns:1fr;gap:var(--space-lg)}.perfume-card.base-perfume{order:1}.similarity-indicator{order:2;flex-direction:row;padding:var(--space-md)}.perfume-card.similar-perfume{order:3}.similarity-arrow{width:50px;height:50px}.similarity-icon{transform:rotate(90deg);font-size:1.25rem}.similar-arrow{order:2;padding:var(--space-sm);flex-direction:row;justify-content:center;align-items:center;gap:var(--space-sm)}.similar-arrow .arrow-icon{font-size:1.5rem}.similar-arrow .arrow-text{font-size:var(--text-sm);color:var(--gray-600);font-weight:500}.similar-actions-improved .action-buttons{grid-template-columns:1fr;gap:var(--space-md)}.similar-actions-improved .action-btn{width:100%;text-align:center}.similar-perfume-column{padding:var(--space-md)}.similar-perfume-column h3{font-size:var(--text-base)}.similar-perfume-column h4{font-size:var(--text-sm);line-height:1.3}}.perfume-column-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--primary-700);margin:0 0 var(--space-lg) 0;text-align:center;padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(139,92,246,.05));border-radius:var(--radius-lg);border:1px solid rgba(139,92,246,.2);box-shadow:0 4px 15px rgba(139,92,246,.1),inset 0 1px 0 rgba(255,255,255,.8);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);position:relative;overflow:hidden}.perfume-column-title:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 80% 20%,rgba(139,92,246,.1) 0,transparent 60%);pointer-events:none}.perfume-column-title:hover{background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(139,92,246,.08));border-color:rgba(139,92,246,.3);box-shadow:0 6px 20px rgba(139,92,246,.15),inset 0 1px 0 rgba(255,255,255,.9);transform:translateY(-1px)}.similar-arrow .arrow-icon{font-size:2rem;color:var(--primary-500)}.similar-arrow .arrow-text{font-size:var(--text-sm);color:var(--gray-600);font-weight:500;text-align:center}@media (min-width:901px){.similar-arrow{flex-direction:column;gap:var(--space-sm)}.similar-arrow .arrow-icon{font-size:2rem}.similar-arrow .arrow-text{font-size:var(--text-sm)}}.emotion-score,.emotion-similarity{font-size:var(--text-sm);font-weight:500;color:var(--primary-600);background:var(--primary-50);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.search-history{position:absolute;top:100%;left:0;right:0;z-index:9999;margin-top:2px}.search-history-container{background:white;border:1px solid var(--gray-300);border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:0 4px 16px rgba(0,0,0,.1);overflow:hidden}.search-history-header{padding:var(--space-sm) var(--space-lg);background:var(--gray-50);border-bottom:1px solid var(--gray-200);font-size:var(--text-sm);font-weight:500;color:var(--gray-600);font-family:var(--font-primary)}.search-history-list{max-height:200px;overflow-y:auto}.search-history-item{display:block;width:100%;padding:var(--space-md) var(--space-lg);border:none;background:white;text-align:left;font-size:var(--text-sm);font-family:var(--font-primary);color:var(--gray-700);cursor:pointer;transition:all .2s ease;border-bottom:1px solid var(--gray-100)}.search-history-item:hover{background:var(--primary-50);color:var(--primary-600)}.search-history-item:last-child{border-bottom:none}.clear-history-btn{display:block;width:100%;padding:var(--space-sm) var(--space-lg);border:none;background:var(--gray-100);border-top:1px solid var(--gray-200);font-size:var(--text-sm);font-family:var(--font-primary);color:var(--gray-600);cursor:pointer;transition:all .2s ease}.clear-history-btn:hover{background:var(--gray-200);color:var(--gray-700)}@media (max-width:900px){.search-history-container{border-radius:0 0 var(--radius-md) var(--radius-md)}.search-history-item{padding:var(--space-sm) var(--space-md);font-size:.8rem}.clear-history-btn,.search-history-header{padding:var(--space-sm) var(--space-md);font-size:.75rem}}.user-preference-analysis{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:800px;max-height:80vh;overflow-y:auto;padding:var(--space-xl);background:linear-gradient(to bottom right,#ffffff,#fdfdff);border:1px solid var(--gray-200);border-radius:var(--radius-xl);box-shadow:0 20px 45px -15px rgba(0,0,0,.15),inset 0 1px 2px rgba(255,255,255,.7),inset 0 -1px 1px rgba(0,0,0,.03);z-index:1000}.user-preference-analysis:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:transparent;z-index:-1}.user-preference-analysis h3{font-family:var(--font-display);font-size:var(--display-base);font-weight:600;margin:0 0 var(--space-lg) 0;color:var(--primary-600);text-align:center;display:flex;justify-content:space-between;align-items:center}.close-analysis-btn{width:36px;height:36px;background:transparent;border:none;border-radius:50%;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--gray-500)}.close-analysis-btn:hover{background:var(--gray-100);color:var(--gray-700);transform:scale(1.1)}.clear-data-btn{width:36px;height:36px;background:transparent;border:none;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--gray-500);margin-left:var(--space-sm)}.clear-data-btn:hover{background:#fee2e2;color:#ef4444;transform:scale(1.1)}.analysis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:var(--space-lg);gap:var(--space-lg)}.analysis-item{background:linear-gradient(145deg,#ffffff,#f9fafb);padding:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--gray-200);box-shadow:0 8px 16px -4px rgba(0,0,0,.08),inset 0 1px 0 rgba(255,255,255,.5)}.analysis-item h4{font-family:var(--font-primary);font-size:var(--text-base);font-weight:600;margin:0 0 var(--space-md) 0;color:var(--gray-700);border-bottom:1px solid var(--gray-200);padding-bottom:var(--space-sm)}.analysis-item ul{list-style:none;padding:0;margin:0}.analysis-item li{padding:var(--space-xs) 0;font-size:var(--text-sm);color:var(--gray-600);border-bottom:1px solid var(--gray-100)}.analysis-item li:last-child{border-bottom:none}.analysis-item p{margin:var(--space-xs) 0;font-size:var(--text-sm);color:var(--gray-600)}@media (max-width:900px){.user-preference-analysis{width:95%;max-height:85vh;padding:var(--space-lg)}.analysis-grid{grid-template-columns:1fr;gap:var(--space-md)}.analysis-item{padding:var(--space-sm)}.analysis-item h4{font-size:var(--text-sm)}.analysis-item li,.analysis-item p{font-size:.8rem}}