/* Admissions Pro — Author: Core Client */
:root{
  --adp-secondary:#ff6b3d;
  --adp-primary:#264528;
  --adp-accent:#1abc9c;
  --adp-light:#ffffff;
  --adp-gray:#f3f3f3;
  --adp-shadow:rgba(0,0,0,.12);
}

/* Warm background */
body{
  background:radial-gradient(circle at top left,#fffaf5 0%,#f4eee9 40%,#efe7df 100%);
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,'Helvetica Neue',Arial,'Apple Color Emoji','Segoe UI Emoji';
}

/* Notices */
.adp-notice{background:#fff3cd;border:1px solid #ffeeba;color:#856404;padding:12px;border-radius:8px}

/* Loader */
.loader-overlay{position:fixed;inset:0;background:rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center;z-index:3000}
.spinner{width:48px;height:48px;border:4px solid #eee;border-top:4px solid var(--adp-primary);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Nav */
.adp-nav{
  position:fixed;left:0;top:0;height:100%;width:230px;background:rgba(241,241,241,.90);
  backdrop-filter:blur(12px);border-right:1px solid var(--adp-shadow);box-shadow:2px 0 8px var(--adp-shadow);
  display:flex;flex-direction:column;align-items:center;overflow-y:auto;z-index:999
}
.adp-nav a{position:relative;width:80%;margin:0 0 1rem;padding:12px 16px;display:flex;align-items:center;gap:10px;
  font-size:.95rem;font-weight:600;color:var(--adp-primary);text-decoration:none;border-radius:8px;transition:.25s;overflow:hidden}
.adp-nav a i{font-size:1.1rem;color:var(--adp-primary)}
.adp-nav a::before{content:'';position:absolute;top:0;left:0;width:5px;height:100%;
  background:linear-gradient(to bottom,#ff6f61,#ff8a80);transform:scaleY(0);transform-origin:top;transition:transform .3s ease}
.adp-nav a:hover,.adp-nav a.active{background:var(--adp-primary);color:#fff;transform:scale(1.05);box-shadow:0 4px 12px var(--adp-shadow)}
.adp-nav a:hover i,.adp-nav a.active i{color:#fff}
.adp-nav a:hover::before,.adp-nav a.active::before{transform:scaleY(1)}
.nav-separator{width:80%;height:1px;background:var(--adp-primary);margin:.5rem 0 1rem}
.adp-logo{display:flex;justify-content:center;align-items:center;margin-top:10px}

@media(max-width:850px){
  .adp-nav{flex-direction:row;width:100%;height:60px;bottom:0;top:auto;border-right:none;border-top:1px solid var(--adp-shadow);box-shadow:0 -2px 6px var(--adp-shadow)}
  .adp-nav a{flex:1;margin:0;flex-direction:column;padding:8px 4px;font-size:.75rem}
  .adp-logo{display:none}
}

/* Content & Sections */
.adp-content{margin-left:230px;padding:2rem;display:flex;flex-wrap:wrap;gap:20px}
@media(max-width:850px){.adp-content{margin:70px 0 70px;padding:1rem}}
.adp-section{display:none;width:100%;background:#fff;border-radius:8px;box-shadow:0 2px 8px var(--adp-shadow);padding:1.5rem;animation:fade .3s}
.adp-section.active{display:block}
.adp-section h2{margin-bottom:1rem;color:#e65100}
@keyframes fade{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}

/* Dashboard Cards */
.dashboard-cards{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:2rem}
.dashboard-cards .card{background:#fff;border-radius:12px;padding:1.4rem;box-shadow:0 8px 18px var(--adp-shadow);position:relative;overflow:hidden;transition:transform .25s}
.dashboard-cards .card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--adp-primary),var(--adp-accent));opacity:.1}
.dashboard-cards .card:hover{transform:translateY(-6px)}
.dashboard-cards .card h3{font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;margin:0 0 .4rem;color:#555}
.dashboard-cards .card p{margin:0;font-size:1.6rem;font-weight:700;color:#d84315}
.dashboard-cards .card:hover{transform:translateY(-8px);box-shadow:0 10px 20px var(--adp-shadow)}

/* Buttons */
.adp-btn{background:var(--adp-primary);color:#fff;border:none;border-radius:8px;padding:.55rem 1.1rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .3s,transform .2s;display:inline-flex;align-items:center;gap:8px}
.adp-btn:hover{background:#ff6f61;transform:translateY(-2px)}

/* Tables */
.table-container{width:100%;overflow-x:auto}
.adp-table{width:100%;border-collapse:collapse;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px var(--adp-shadow);font-size:.95rem;background:#fff}
.adp-table th{background:var(--adp-primary);color:#fff;text-align:left;padding:1rem}
.adp-table td{padding:1rem}
.adp-table tbody tr:nth-child(even){background:var(--adp-gray)}
.adp-table tbody tr:hover{background:#fff3e0}

/* Search */
.section-search{display:flex;justify-content:flex-end;margin-bottom:1rem}
.section-search input{width:260px;padding:.6rem 1rem;border:1px solid #ccc;border-radius:8px;transition:border .25s}
.section-search input:focus{border-color:var(--adp-primary);outline:none;background:#fff3e0}

/* Open Houses */
.openhouse-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.openhouse-card{background:#fff;border-radius:12px;box-shadow:0 4px 12px var(--adp-shadow);padding:1.2rem;cursor:default;transition:transform .25s}
.openhouse-card:hover{transform:translateY(-5px)}
.openhouse-card h3{margin:.1rem 0;font-size:1.1rem;color:var(--adp-primary)}
.openhouse-card p{margin:.15rem 0;color:#555;font-size:.9rem}

/* Messages */
.message-center{display:flex;gap:20px;flex-wrap:wrap}
.message-threads{flex:0 0 260px;background:#fff;border-radius:8px;box-shadow:0 2px 8px var(--adp-shadow);overflow:hidden}
.thread-item{padding:.9rem 1rem;border-bottom:1px solid #eee;cursor:pointer;transition:background .2s}
.thread-item.active,.thread-item:hover{background:#eef5ff}
.message-view{flex:1;background:#fff;border-radius:8px;box-shadow:0 2px 8px var(--adp-shadow);padding:1rem;display:flex;flex-direction:column}
.message-log{flex:1;overflow-y:auto;padding-right:.5rem}
.msg{margin-bottom:.8rem;font-size:.9rem}
.msg.you{font-weight:600;color:var(--adp-primary)}
.message-compose{display:flex;gap:10px;margin-top:1rem}
.message-compose textarea{flex:1;border:1px solid #ddd;border-radius:8px;padding:.6rem;min-height:60px}
.send-btn{background:var(--adp-primary);color:#fff;border:none;border-radius:8px;padding:.6rem 1rem}

/* Modal */
.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);justify-content:center;align-items:center;z-index:2000}
.modal-content{background:#fffaf5;width:95%;max-width:900px;max-height:90vh;padding:1rem;border-radius:12px;box-shadow:0 8px 24px var(--adp-shadow);position:relative;animation:fade .3s;overflow:auto}
.close-button{position:absolute;top:10px;right:18px;font-size:1.6rem;color:#888;cursor:pointer}
.close-button:hover{color:#000}

/* Simple form grid helpers */
.adp-form label{display:block;font-size:.85rem;margin-bottom:.2rem;color:#333}
.adp-form input, .adp-form select, .adp-form textarea{width:100%;padding:.55rem;border:1px solid #ccc;border-radius:8px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.grid-1{display:grid;grid-template-columns:1fr;gap:10px}
fieldset{border:1px solid #eee;border-radius:8px;padding:10px;margin-top:10px}
legend{padding:0 6px;color:#555}
.settings-group{margin-bottom:12px}

/* Public Signup */
.adp-signup{max-width:900px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 2px 8px var(--adp-shadow);padding:1.2rem}
.adp-signup-header{text-align:center;margin-bottom:12px}
.adp-signup-logo{max-height:60px;display:inline-block;margin-bottom:6px}
.adp-success{margin-top:10px;background:#e8f5e9;border:1px solid #a5d6a7;padding:.8rem;border-radius:8px;color:#1b5e20}
.adp-error{margin-top:10px;background:#ffebee;border:1px solid #ef9a9a;padding:.8rem;border-radius:8px;color:#b71c1c}


/* Shortcode + Registrants styling */
.shortcode-box{display:flex;align-items:center;gap:8px;background:#fffaf2;border:1px dashed #f3b37c;padding:.5rem;border-radius:8px;margin:.5rem 0}
.shortcode-box .sc-label{font-size:.85rem;color:#7a4a12}
.shortcode-box .sc-code{background:#fff;border:1px solid #f1d9c2;padding:.2rem .4rem;border-radius:6px;display:inline-block}
.registrants{margin-top:.8rem}
.registrants-title{font-weight:700;margin-bottom:.4rem;color:#333}
.registrants-empty,.registrants-error{padding:.5rem;border-radius:6px;background:#fff3cd;border:1px solid #ffe8a1;color:#6b5a00}


/* Dashboard logo image */
.adp-logo-img{max-height:48px;display:block}


/* inline button row helper */
.adp-btns-row{display:inline-flex;gap:6px;flex-wrap:wrap}

.adp-modal[aria-hidden="true"] { display: none; }
.adp-modal[aria-hidden="false"] { display: block; }
.adp-kv > div { display:flex; gap:.5rem; margin:.25rem 0; }
.adp-kv span { min-width: 90px; color: #666; }
.adp-family__children table,
.adp-family__registrations table { width:100%; }

/* =========================
   Mobile-friendly additions
   ========================= */

/* Slightly reduce card/table text on medium screens */
@media (max-width: 1024px){
  .dashboard-cards .card p{font-size:1.4rem}
  .adp-table{font-size:.9rem}
}

/* Collapse form grids and tighten paddings on tablets/phones */
@media (max-width: 768px){
  .grid-3{grid-template-columns:1fr 1fr}
  .adp-section{padding:1.1rem}
  .message-center{flex-direction:column}
  .message-threads{flex:unset;width:100%}
}

/* Phone-first tweaks */
@media (max-width: 600px){
  /* Content spacing */
  .adp-content{gap:14px}

  /* Dashboard cards: bigger tap targets, single column if needed by container */
  .dashboard-cards{gap:14px}

  /* Buttons & inputs */
  .adp-btn{width:100%;justify-content:center;padding:.75rem 1rem}
  .message-compose{flex-direction:column}
  .send-btn{width:100%;padding:.75rem 1rem}

  /* Tables: improve readability without changing structure */
  .adp-table th,
  .adp-table td{padding:.75rem;word-break:break-word}
  .table-container{margin:0 -8px;padding:0 8px} /* allow gentle horizontal pan */
  .adp-table th:first-child,
  .adp-table td:first-child{position:sticky;left:0;background:rgba(255,255,255,.98)} /* keep first column visible when panning */

  /* Search input full width */
  .section-search{justify-content:stretch}
  .section-search input{width:100%}

  /* Open house cards */
  .openhouse-grid{grid-template-columns:1fr}

  /* Modal: edge-to-edge on phones */
  .modal-content{width:100%;max-width:none;border-radius:10px}
}

/* Very small devices */
@media (max-width: 420px){
  .adp-section h2{font-size:1.05rem}
  .dashboard-cards .card h3{font-size:.85rem}
  .dashboard-cards .card p{font-size:1.2rem}
  .adp-table{font-size:.88rem}
  .adp-form label{font-size:.8rem}
}
