/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-600:oklch(57.7% .245 27.325);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-white:#fff;--spacing:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.my-1{margin-block:calc(var(--spacing) * 1)}.block{display:block}.flex{display:flex}.grid{display:grid}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-px{height:1px}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-56{width:calc(var(--spacing) * 56)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.gap-2{gap:calc(var(--spacing) * 2)}.gap-6{gap:calc(var(--spacing) * 6)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-gray-200{border-color:var(--color-gray-200)}.bg-gray-200{background-color:var(--color-gray-200)}.bg-white{background-color:var(--color-white)}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.py-2{padding-block:calc(var(--spacing) * 2)}.text-red-600{color:var(--color-red-600)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}@media (hover:hover){.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}}@media (min-width:48rem){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}}:root{--bg:#fafafa;--bg-alt:#fff;--text:#374151;--text-light:#806b6b;--accent:#2563eb;--accent-hover:#1d4ed8;--border:#e5e7eb;--shadow:0 1px 3px #0000001a;--shadow-lg:0 10px 40px #0000001a;--danger:#dc2626;--success:#16a34a}[data-theme=dark]{--bg:#0f172a;--bg-alt:#1e293b;--text:#f0e2e2;--text-light:#b89494;--accent:#3b82f6;--accent-hover:#60a5fa;--border:#334155;--shadow:0 1px 3px #0000004d;--shadow-lg:0 10px 40px #0006;--danger:#ef4444;--success:#22c55e}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--bg:#0f172a;--bg-alt:#1e293b;--text:#fff;--text-light:#fff;--accent:#3b82f6;--accent-hover:#60a5fa;--border:#334155;--shadow:0 1px 3px #0000004d;--shadow-lg:0 10px 40px #0006;--danger:#ef4444;--success:#22c55e}}*,:before,:after{box-sizing:border-box;margin:0;padding:0;transition:background-color .3s,color .3s,border-color .3s,box-shadow .3s}html{scroll-behavior:smooth;color-scheme:light dark}body{color:var(--text);background-color:var(--bg);background-image:radial-gradient(var(--border) 3px,transparent 4px);background-size:40px 40px;background-attachment:fixed;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.6}.app{flex-direction:column;min-height:100vh;display:flex}.loading-screen{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}main{flex:1}section#home,section#projects,section#contact{flex-direction:column;justify-content:center;width:100%;max-width:1200px;min-height:100dvh;margin:0 auto;padding:6rem 2rem 4rem;display:flex}.footer-links{justify-content:center;gap:1.5rem;margin-bottom:.75rem;display:flex}.footer-links a{color:var(--accent);border:1px solid var(--border);border-radius:8px;padding:.4rem .8rem;font-weight:500;text-decoration:none;transition:all .2s}.footer-links a:hover{background:var(--bg-alt);border-color:var(--accent)}.navbar{background:var(--bg-alt);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex;position:fixed;top:0;left:0;right:0}.nav-links{gap:2rem;display:flex;position:relative;left:50%;transform:translate(-50%)}.nav-links a{color:var(--text-light);padding-bottom:4px;text-decoration:none;transition:color .2s}.nav-links a.active{color:var(--text)}.nav-indicator{background:var(--accent);width:0;height:2px;transition:all .25s cubic-bezier(.4,0,.2,1);position:absolute;bottom:0;left:0}.nav-auth{align-items:center;gap:1rem;display:flex;position:absolute;top:50%;right:2rem;transform:translateY(-50%)}.theme-toggle{border:1px solid var(--border);cursor:pointer;color:var(--text-light);background:0 0;border-radius:8px;justify-content:center;align-items:center;padding:.4rem;transition:all .2s;display:flex}.theme-toggle:hover{color:var(--text);border-color:var(--accent)}.lang-toggle{border:1px solid var(--border);cursor:pointer;color:var(--text-light);background:0 0;border-radius:8px;justify-content:center;align-items:center;padding:.4rem .6rem;font-size:.8rem;font-weight:600;transition:all .2s;display:flex}.lang-toggle:hover{color:var(--text);border-color:var(--accent)}.hero{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;display:grid}.hero-content h1{margin-bottom:1.5rem;font-size:3rem;font-weight:650;line-height:1.1}.highlight{color:var(--accent)}.hero-subtitle{color:var(--text-light);margin-bottom:2rem;font-size:1.25rem}.hero-buttons{gap:1rem;display:flex}.hero-visual{justify-content:center;align-items:center;display:flex}.code-block{color:#e2e8f0;box-shadow:var(--shadow-lg);background:#1e293b;border-radius:12px;padding:2rem;font-family:Monaco,Menlo,monospace;font-size:1.125rem}[data-theme=dark] .code-block{border:1px solid var(--border);background:#0f172a}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .code-block{border:1px solid var(--border);background:#0f172a}}.code-tag{color:#94a3b8}.code-name{color:#38bdf8}.code-text{color:#fff}.section-title{text-align:center;margin-bottom:.5rem;font-size:2.5rem}.section-subtitle{text-align:center;color:var(--text-light);margin-bottom:3rem;font-size:1.125rem}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;display:grid}.project-card{background:var(--bg-alt);border:1px solid var(--border);border-radius:12px;transition:all .3s;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.project-image img{object-fit:cover;width:400px;height:200px}.project-content{padding:1.5rem}.project-content h3{margin-bottom:.5rem}.project-content p{color:var(--text-light);margin-bottom:1rem;font-size:.95rem}.tech-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.tech-tag{background:var(--bg-alt);color:var(--accent);border:1px solid var(--border);border-radius:999px;padding:.25rem .75rem;font-size:.75rem;font-weight:500}.project-links{gap:1rem;display:flex}.project-link{color:var(--accent);font-size:.875rem;font-weight:500;text-decoration:none}.project-link:hover{text-decoration:underline}.loading,.error,.no-projects{text-align:center;color:var(--text-light);padding:3rem}.form-group{margin-bottom:1.5rem}.form-group label{margin-bottom:.5rem;font-weight:500;display:block}.form-group input,.form-group textarea{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:8px;padding:.875rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);outline:none}.contact-form{max-width:600px;margin:0 auto 3rem}.contact-info{text-align:center;color:var(--text-light);flex-wrap:wrap;justify-content:center;gap:2rem;margin-top:2rem;display:flex}.contact-info a{color:var(--accent);border:1px solid var(--border);border-radius:8px;padding:.5rem 1rem;font-weight:500;text-decoration:none;transition:all .2s}.contact-info a:hover{background:var(--bg-alt);border-color:var(--accent)}.contact-form-wrapper{max-width:600px;margin:0 auto 3rem}.contact-form-wrapper .contact-form{max-width:none;margin:0 0 1rem}.status-message{text-align:center;border-radius:8px;width:100%;padding:1rem}.status-message.success{color:var(--success);background:#dcfce7}.status-message.error{color:var(--danger);background:#fef2f2}.login-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.login-modal{background:var(--bg-alt);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border-radius:12px;padding:2rem;position:relative}.close-btn{cursor:pointer;color:var(--text-light);background:0 0;border:none;font-size:1.5rem;position:absolute;top:1rem;right:1rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h2{margin-bottom:.5rem;font-size:1.75rem}.login-header p{color:var(--text-light);font-size:.875rem}.login-form{margin-bottom:1.5rem}.error-message{color:var(--danger);background:#fef2f2;border-radius:8px;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.login-footer{text-align:center;color:var(--text-light);font-size:.875rem}.link-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;margin-left:.5rem;font-weight:500}.link-btn:hover{text-decoration:underline}.auth-page{background-color:var(--bg);background-image:radial-gradient(var(--border) 4px,transparent 4px);background-size:40px 40px;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-container{width:100%;max-width:420px}.auth-back{background:var(--bg-alt);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;display:inline-flex}.auth-back:hover{background:var(--bg);border-color:var(--accent);color:var(--accent)}.auth-card{background:var(--bg-alt);box-shadow:var(--shadow-lg);border:1px solid var(--border);border-radius:16px;padding:2.5rem}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h2{margin-bottom:.5rem;font-size:1.75rem}.auth-header p{color:var(--text-light);font-size:.9rem}.auth-form{margin-bottom:1.5rem}.auth-footer{text-align:center;color:var(--text-light);font-size:.875rem}.btn{cursor:pointer;border:1px solid #1e1e1e;border-radius:8px;padding:.6rem 1.2rem;font-weight:500;transition:all .2s}.btn-primary{color:#1e1e1e;background:#fff}.btn-primary:hover{background:#d3d3d3}.btn-secondary{background:var(--accent);color:#fff;border:none}.btn-secondary:hover{background:var(--accent-hover)}.btn-login{background:var(--accent);color:#fff;border:none;justify-content:center;align-items:center;gap:.5rem;width:100%;font-size:large;display:flex}.btn-login:hover{background:var(--accent-hover)}.btn-outline{border:1px solid var(--border);color:var(--text);background:0 0;justify-content:center;align-items:center;gap:.5rem;display:flex}.btn-outline:hover{background:var(--bg)}.btn-outline-dashboard-header{border:1px solid var(--border);color:var(--text);background:#fff;justify-content:center;align-items:center;gap:.5rem;display:flex}.btn-outline-dashboard-header:hover{background:var(--bg)}.btn-plus{color:#000;background:0 0;border:none}.btn-trash{color:red;background:0 0;border:none}.btn-edit{color:#000;background:0 0;border:none}.btn-danger{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.2rem;font-weight:500;transition:background .2s}.btn-danger:hover{opacity:.85}.dashboard{background-color:var(--bg);background-image:radial-gradient(var(--border) 4px,transparent 4px);background-size:40px 40px;background-attachment:fixed;min-height:100vh}.dashboard-inner{max-width:1400px;margin:0 auto;padding:24px}.dashboard-header{justify-content:flex-end;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.dashboard-header>*{flex-shrink:0}.dashboard-header .theme-toggle{background:var(--bg-alt);border:1px solid var(--border);cursor:pointer;color:var(--text-light);border-radius:8px;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.dashboard-header .theme-toggle:hover{color:var(--text);border-color:var(--accent)}.dashboard-header .btn-outline-dashboard-header{background:var(--bg-alt);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.dashboard-header .btn-outline-dashboard-header:hover{background:var(--bg);border-color:var(--accent);color:var(--accent)}.dashboard-messages{background:var(--bg-alt);border:1px solid var(--border);max-height:380px;box-shadow:var(--shadow);border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.dashboard-messages .messages-list{flex:1;overflow-y:auto}.messages-header{border-bottom:1px solid var(--border);color:var(--text);align-items:center;gap:.5rem;padding:14px 20px;font-weight:600;display:flex}.message-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;padding:12px 20px;transition:background .2s;display:flex}.message-item:last-child{border-bottom:none}.message-item:hover{background:var(--bg)}.message-item{border-left:3px solid var(--border)}.message-item.unread{border-left:3px solid var(--accent);background:#3b82f60a}[data-theme=dark] .message-item.unread{background:#3b82f614}.message-item.unread .message-sender{color:var(--accent);font-weight:700}.message-item:not(.unread) .message-sender{color:var(--text);font-weight:500}.message-content-wrapper{justify-content:space-between;align-items:flex-start;gap:12px;width:100%;display:flex}.message-info{flex:1;min-width:0}.message-sender{color:var(--text);margin-bottom:2px;font-size:.875rem;font-weight:600;display:block}.message-text{color:var(--text-light);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.8125rem;line-height:1.4;overflow:hidden}.delete-btn{color:var(--text-light);cursor:pointer;opacity:.5;background:0 0;border:none;flex-shrink:0;padding:4px;font-size:1.1rem;transition:opacity .2s}.delete-btn:hover{opacity:1;color:var(--text)}[data-theme=dark] .delete-btn{opacity:.7}[data-theme=dark] .delete-btn:hover{opacity:1}.dashboard-grid{grid-template-columns:1fr 1fr;align-items:start;gap:24px;margin-top:1.5rem;display:grid}.dashboard-card{background:var(--bg-alt);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;overflow:hidden}.card-header{border-bottom:1px solid var(--border);color:var(--text);justify-content:space-between;align-items:center;padding:14px 20px;font-weight:600;display:flex}.empty-state{text-align:center;color:var(--text-light);padding:3rem 2rem}.projects-list{border:none;border-radius:0}.project-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:12px 20px;display:flex}.project-item:last-child{border-bottom:none}.project-left{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.project-info{flex:1;min-width:0}.project-info h3{color:var(--text);margin:0;font-size:.95rem}.project-info p{color:var(--text-light);text-overflow:ellipsis;white-space:nowrap;margin:2px 0 4px;font-size:.8rem;overflow:hidden}.tags{flex-wrap:wrap;gap:4px;margin-bottom:4px;display:flex}.tags span{background:var(--bg);color:var(--accent);border-radius:999px;padding:2px 8px;font-size:.6875rem}.links a{color:var(--accent);margin-right:12px;font-size:.75rem;text-decoration:none}.links a:hover{text-decoration:underline}.project-actions{flex-shrink:0;gap:8px;display:flex}.project-actions button{cursor:pointer;color:var(--text-light);background:0 0;border:none;padding:4px;transition:color .2s}.project-actions button:hover{color:var(--text)}.portfolio-form{flex-direction:column;padding:1.5rem;display:flex}.portfolio-form .form-section{margin-bottom:0}.form-section{margin-bottom:1.5rem}.form-section h3{border-bottom:1px solid var(--border);color:var(--text);margin-bottom:.75rem;padding-bottom:.5rem;font-size:1.1rem}.portfolio-form .form-group{margin-bottom:1rem}.portfolio-form input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:6px;padding:8px 12px;font-family:inherit;font-size:.875rem;transition:border-color .2s}.portfolio-form input:focus{border-color:var(--accent);outline:none}.save-bar{justify-content:flex-end;align-items:center;gap:1rem;margin-top:1rem;display:flex}.save-bar .notification{margin-bottom:0;padding:.5rem 1rem;font-size:.85rem}.btn-save{color:#fff;cursor:pointer;background-color:#71b87d;border:none;border-radius:6px;flex-shrink:0;align-items:center;gap:8px;padding:10px 24px;font-size:.9rem;font-weight:500;transition:background .2s;display:flex}.btn-save:hover{background-color:#5fa867}.img-project-dashboard{object-fit:cover;background:var(--bg);border-radius:8px;flex-shrink:0;width:60px;height:60px}.bell-wrapper{color:var(--text-light);align-items:center;display:flex;position:relative}.bell-dot{background:var(--danger);border:2px solid var(--bg-alt);border-radius:50%;width:9px;height:9px;position:absolute;top:2px;right:2px}.badge{background:var(--danger);color:#fff;border-radius:5px;padding:.125rem .4rem;font-size:.75rem;font-weight:600}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.modal{background:var(--bg-alt);width:100%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);border-radius:12px;padding:1.5rem;overflow-y:auto}.modal h3{color:var(--text);margin-bottom:1.25rem}.modal-small{text-align:center;max-width:400px}.modal-small p{color:var(--text-light);margin-bottom:1.25rem}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:1.25rem;display:flex}.modal-large{max-width:600px}.message-detail{margin:1rem 0}.message-content{white-space:pre-wrap;color:var(--text);margin-top:.75rem;line-height:1.6}.footer{background:var(--bg-alt);border-top:1px solid var(--border);text-align:center;color:var(--text-light);padding:2rem}.notification{border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.dashboard-card .notification{margin:0 1.5rem}.notification.success{color:var(--success);background:#dcfce7}.notification.error{color:var(--danger);background:#fef2f2}.btn-plus{color:var(--accent);cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;transition:opacity .2s;display:flex}.btn-plus:hover{opacity:.7}.dashboard-card .card-header .lang-toggle{background:var(--bg);border:1px solid var(--border);cursor:pointer;color:var(--text-light);border-radius:6px;padding:.3rem .6rem;font-size:.8rem;font-weight:600;transition:all .2s}.dashboard-card .card-header .lang-toggle:hover{color:var(--text);border-color:var(--accent)}@media (max-width:768px){.hero{text-align:center;grid-template-columns:1fr}.hero-content h1{font-size:2rem}.hero-buttons{justify-content:center}.hero-visual{order:-1}.code-block{padding:1.5rem;font-size:.875rem}.projects-grid{grid-template-columns:1fr}.navbar{padding:1rem}.nav-links{gap:1rem}.dashboard-nav{flex-direction:column;gap:1rem}.nav-right{flex-wrap:wrap;justify-content:center}.projects-table{overflow-x:auto}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
