/* =========================================
   IVRA PARFUMS - ACCOUNT PORTAL
   ========================================= */

:root {
    --bg-base: #FAF9F6;
    --text-base: #3A3530;
    --accent-gold: #C0A062;
    --ff-serif: 'Cormorant Garamond', serif;
    --ff-sans: 'Montserrat', sans-serif;
    --ff-script: 'Pinyon Script', cursive;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    background: var(--bg-base);
    color: var(--text-base);
    font-family: var(--ff-sans);
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

/* =========================================
   UI EXTENSIONS
   ========================================= */
.noise-overlay {
    position: fixed; inset: -50%; width: 200%; height: 200%; pointer-events: none; z-index: 99998;
    opacity: 0.05; mix-blend-mode: multiply;
    background-image: url('data:image/svg+xml,%3Csvg viewBox="0 0 200 200" xmlns="http://www.w3.org/2000/svg"%3E%3Cfilter id="n"%3E%3CfeTurbulence type="fractalNoise" baseFrequency="0.65" numOctaves="3" stitchTiles="stitch"/%3E%3C/filter%3E%3Crect width="100%25" height="100%25" filter="url(%23n)"/%3E%3C/svg%3E');
    animation: grain 8s steps(10) infinite;
}
@keyframes grain { 0%, 100% { transform: translate(0, 0); } 10% { transform: translate(-5%, -10%); } 30% { transform: translate(7%, -25%); } 50% { transform: translate(-15%, 10%); } }

.btn--solid, .btn--outline {
    display: inline-block; padding: 1.2rem 2.5rem; font-family: var(--ff-sans); font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; cursor: pointer; transition: all 0.4s ease; text-decoration: none; border: none; text-align: center;
}
.btn--solid { background: var(--text-base); color: var(--bg-base); border: 1px solid var(--text-base); }
.btn--solid:hover { background: transparent; color: var(--text-base); }
.btn--solid--full { width: 100%; }
.btn--outline { background: transparent; color: var(--text-base); border: 1px solid var(--text-base); }
.btn--outline:hover { background: var(--text-base); color: var(--bg-base); }

/* Input Fields */
.input-group { position: relative; margin-bottom: 2.5rem; }
.input-group input {
    width: 100%; padding: 1rem 0; font-family: var(--ff-sans); font-size: 1rem; color: var(--text-base);
    background: transparent; border: none; border-bottom: 1px solid rgba(58, 53, 48, 0.2); outline: none; transition: border-color 0.3s ease;
}
.input-group input:focus { border-bottom: 1px solid var(--text-base); }
.input-group label {
    position: absolute; top: 1rem; left: 0; font-family: var(--ff-sans); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase;
    color: rgba(58, 53, 48, 0.6); transition: all 0.3s ease; pointer-events: none;
}
.input-group input:focus ~ label, .input-group input:valid ~ label {
    top: -1rem; font-size: 0.65rem; color: var(--text-base);
}

/* Navbar Minimal */
.navbar { position: fixed; top: 0; left: 0; width: 100%; z-index: 9000; padding: 1.5rem 4vw; transition: background 0.4s ease; display: flex; justify-content: space-between; align-items: center; }
.navbar__logo { font-size: 2rem; font-weight: 500; font-family: var(--ff-serif); color: var(--text-base); text-decoration: none; }
.navbar__links { display: flex; gap: 3vw; font-family: var(--ff-sans); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase; }
.navbar__links a { color: var(--text-base); text-decoration: none; position: relative; padding: 0.5rem; }

/* =========================================
   LOGIN SCREEN (SPLIT)
   ========================================= */
.login-split {
    display: flex; height: 100vh; width: 100%; overflow: hidden;
}
.login__visual {
    width: 50%; position: relative; background: #DBCBAA; overflow: hidden;
}
.login__visual img {
    width: 100%; height: 100%; object-fit: cover; filter: saturate(0.8) contrast(1.1);
}
.login__visual-overlay {
    position: absolute; inset: 0; background: linear-gradient(0deg, rgba(30,28,25,0.4) 0%, rgba(30,28,25,0) 50%); z-index: 2;
}
.login__quote {
    position: absolute; bottom: 10vh; left: 5vw; right: 5vw; z-index: 3; color: var(--bg-base);
}
.login__quote h2 { font-family: var(--ff-serif); font-size: 3rem; font-weight: 300; line-height: 1.2; margin-bottom: 1rem; }
.login__quote p { font-size: 0.8rem; letter-spacing: 0.2em; text-transform: uppercase; }

.login__form-wrapper {
    width: 50%; display: flex; flex-direction: column; justify-content: center; padding: 0 10vw; position: relative; z-index: 5; background: var(--bg-base);
}
.login__form-header { margin-bottom: 4rem; }
.login__form-header h1 { font-family: var(--ff-serif); font-size: 3.5rem; font-weight: 300; margin-bottom: 1rem; line-height: 1; }
.login__form-header p { color: rgba(58, 53, 48, 0.6); line-height: 1.6; }

.login__links {
    margin-top: 2rem; display: flex; justify-content: space-between; font-size: 0.8rem; letter-spacing: 0.05em;
}
.login__links a { color: var(--accent-gold); text-decoration: none; transition: opacity 0.3s ease; }
.login__links a:hover { opacity: 0.7; }

/* Form View Toggle */
.form-view { display: none; opacity: 0; }
.form-view.is-active { display: block; opacity: 1; }

/* =========================================
   ACCOUNT SPA PORTAL
   ========================================= */
.portal {
    display: flex; min-height: 100vh; padding-top: 100px; /* offset navbar */
}

/* Sidebar */
.portal__sidebar {
    width: 25vw; padding: 4rem 4vw; border-right: 1px solid rgba(58, 53, 48, 0.1); position: sticky; top: 100px; height: calc(100vh - 100px); display: flex; flex-direction: column;
}
.portal__user { margin-bottom: 4rem; }
.portal__user-greeting { font-family: var(--ff-sans); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent-gold); display: block; margin-bottom: 0.5rem; }
.portal__user-name { font-family: var(--ff-serif); font-size: 2.5rem; font-weight: 300; }

.portal__nav { display: flex; flex-direction: column; gap: 1.5rem; flex: 1; }
.portal__nav-link {
    font-family: var(--ff-sans); font-size: 0.85rem; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(58, 53, 48, 0.5); text-decoration: none; transition: color 0.3s ease; position: relative; display: inline-flex; align-items: center; cursor: pointer;
}
.portal__nav-link::before {
    content: ''; position: absolute; left: -1.5rem; top: 50%; transform: translateY(-50%) scale(0); width: 4px; height: 4px; border-radius: 50%; background: var(--accent-gold); transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1);
}
.portal__nav-link:hover { color: var(--text-base); }
.portal__nav-link.is-active { color: var(--text-base); }
.portal__nav-link.is-active::before { transform: translateY(-50%) scale(1); }

.portal__logout { margin-top: auto; color: var(--accent-gold); font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; text-decoration: none; transition: opacity 0.3s ease; }

/* Main Content Area */
.portal__main {
    width: 75vw; padding: 4rem 6vw 8rem 6vw; position: relative;
}
.portal__view {
    display: none; opacity: 0;
}
.portal__view.is-active {
    display: block; opacity: 1;
}

.view-header { margin-bottom: 4rem; }
.view-header h2 { font-family: var(--ff-serif); font-size: 3.5rem; font-weight: 300; line-height: 1; margin-bottom: 1rem; }
.view-header p { color: rgba(58, 53, 48, 0.6); max-width: 600px; line-height: 1.6; }

/* Dashboard Quick Tiles */
.dash-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; }
.dash-card {
    padding: 3rem; background: rgba(58, 53, 48, 0.03); border: 1px solid rgba(58, 53, 48, 0.05); border-radius: 4px; transition: background 0.3s ease;
}
.dash-card:hover { background: rgba(58, 53, 48, 0.05); }
.dash-card h3 { font-family: var(--ff-serif); font-size: 2rem; font-weight: 300; margin-bottom: 1rem; }
.dash-card .count { font-family: var(--ff-sans); font-size: 3rem; font-weight: 200; color: var(--accent-gold); display: block; margin-bottom: 1rem; }

/* Orders List */
.orders-list { display: flex; flex-direction: column; gap: 1rem; }
.order-item {
    border: 1px solid rgba(58, 53, 48, 0.1); border-radius: 4px; overflow: hidden;
}
.order-header {
    display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; padding: 2rem; background: var(--bg-base); cursor: pointer; transition: background 0.3s ease; align-items: center;
}
.order-header:hover { background: rgba(58, 53, 48, 0.02); }
.col-label { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent-gold); display: block; margin-bottom: 0.5rem;}
.col-val { font-family: var(--ff-serif); font-size: 1.5rem; font-weight: 300; color: var(--text-base); }
.order-status { display: inline-block; padding: 0.4rem 0.8rem; font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; background: rgba(192, 160, 98, 0.1); color: var(--accent-gold); border-radius: 2px; }

/* expanding details row (hidden by default) */
.order-details {
    padding: 0; max-height: 0; overflow: hidden; transition: all 0.5s cubic-bezier(0.25, 1, 0.5, 1); background: #FAF9F6;
}
.order-item.is-open .order-details { padding: 2rem; max-height: 500px; border-top: 1px solid rgba(58, 53, 48, 0.05); }
.order-products { display: flex; gap: 2rem; }
.product-mini { display: flex; gap: 1rem; align-items: center; }
.product-mini img { width: 60px; height: 80px; object-fit: cover; border-radius: 2px; }
.product-mini span { font-family: var(--ff-sans); font-size: 0.9rem; }

/* Address Book */
.addr-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; }
.addr-card {
    padding: 3rem; border: 1px solid rgba(58, 53, 48, 0.2); border-radius: 4px; position: relative;
}
.addr-label { position: absolute; top: 1.5rem; right: 2rem; font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent-gold); }
.addr-card h3 { font-family: var(--ff-serif); font-size: 2rem; font-weight: 300; margin-bottom: 1rem; }
.addr-card p { font-size: 0.95rem; line-height: 1.8; color: rgba(58, 53, 48, 0.7); margin-bottom: 2rem; }

/* Settings Form Grid */
.settings-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; max-width: 800px; }

/* Responsive adjustments */
@media (max-width: 1024px) {
    .login-split { flex-direction: column; height: auto; }
    .login__visual, .login__form-wrapper { width: 100%; }
    .login__visual { height: 40vh; }
    .login__form-wrapper { padding: 4rem 5vw; }
    
    .portal { flex-direction: column; }
    .portal__sidebar { width: 100%; height: auto; position: static; border-right: none; border-bottom: 1px solid rgba(58, 53, 48, 0.1); padding: 2rem 5vw; }
    .portal__nav { flex-direction: row; flex-wrap: wrap; }
    .portal__main { width: 100%; padding: 3rem 5vw; }
    .dash-grid, .addr-grid, .settings-grid { grid-template-columns: 1fr; }
    .order-header { grid-template-columns: 1fr 1fr; gap: 1rem; }
}
